js 字符串转换成数字的三种方法


Posted in Javascript onMarch 23, 2013

方法主要有三种

转换函数、强制类型转换、利用js变量弱类型转换。

1. 转换函数:

js提供了parseInt()和parseFloat()两个转换函数。前者把值转换成整数,后者把值转换成浮点数。只有对String类型调用这些方法,这两个函数才能正确运行;对其他类型返回的都是NaN(Not a Number)。

一些示例如下:

parseInt("1234blue");   //returns   1234
parseInt("0xA");   //returns   10
parseInt("22.5");   //returns   22
parseInt("blue");   //returns   NaN

parseInt()方法还有基模式,可以把二进制、八进制、十六进制或其他任何进制的字符串转换成整数。基是由parseInt()方法的第二个参数指定的,示例如下:

parseInt("AF",   16);   //returns   175
parseInt("10",   2);   //returns   2
parseInt("10",   8);   //returns   8
parseInt("10",   10);   //returns   10

如果十进制数包含前导0,那么最好采用基数10,这样才不会意外地得到八进制的值。例如:

parseInt("010");   //returns   8
parseInt("010",   8);   //returns   8
parseInt("010",   10);   //returns   10

parseFloat()方法与parseInt()方法的处理方式相似。
使用parseFloat()方法的另一不同之处在于,字符串必须以十进制形式表示浮点数,parseFloat()没有基模式。

下面是使用parseFloat()方法的示例:

parseFloat("1234blue");   //returns   1234.0
parseFloat("0xA");   //returns   NaN
parseFloat("22.5");   //returns   22.5
parseFloat("22.34.5");   //returns   22.34
parseFloat("0908");   //returns   908
parseFloat("blue");   //returns   NaN

2. 强制类型转换

还可使用强制类型转换(type casting)处理转换值的类型。使用强制类型转换可以访问特定的值,即使它是另一种类型的。
ECMAScript中可用的3种强制类型转换如下:
Boolean(value)——把给定的值转换成Boolean型;
Number(value)——把给定的值转换成数字(可以是整数或浮点数);
String(value)——把给定的值转换成字符串。
用这三个函数之一转换值,将创建一个新值,存放由原始值直接转换成的值。这会造成意想不到的后果。
当要转换的值是至少有一个字符的字符串、非0数字或对象(下一节将讨论这一点)时,Boolean()函数将返回true。如果该值是空字符串、数字0、undefined或null,它将返回false。

可以用下面的代码段测试Boolean型的强制类型转换。

Boolean("");   //false   ?   empty   string
Boolean("hi");   //true   ?   non-empty   string
Boolean(100);   //true   ?   non-zero   number
Boolean(null);   //false   -   null
Boolean(0);   //false   -   zero
Boolean(new   Object());   //true   ?   object

Number()的强制类型转换与parseInt()和parseFloat()方法的处理方式相似,只是它转换的是整个值,而不是部分值。示例如下:

用法                   结
果
Number(false)                  0
Number(true)                   1
Number(undefined)              NaN
Number(null)                   0
Number( "5.5 ")                5.5
Number( "56 ")                 56
Number( "5.6.7 ")              NaN
Number(new   Object())         NaN
Number(100)                    100

最后一种强制类型转换方法String()是最简单的,示例如下:

var   s1   =   String(null);   //"null"
var   oNull   =   null;
var   s2   =   oNull.toString();   //won't   work,   causes   an   error

3. 利用js变量弱类型转换

举个小例子,一看,就会明白了。

<script>
var   str= '012.345 ';
var   x   =   str-0;
x   =   x*1;
</script>

上例利用了js的弱类型的特点,只进行了算术运算,实现了字符串到数字的类型转换,不过这个方法还是不推荐的

Javascript 相关文章推荐
用JQuery实现表格隔行变色和突出显示当前行的代码
Feb 10 Javascript
js实现为a标签添加事件的方法(使用闭包循环)
Aug 02 Javascript
Bootstrop实现多级下拉菜单功能
Nov 24 Javascript
jquery广告无缝轮播实例
Jan 05 Javascript
bootstrap table分页模板和获取表中的ID方法
Jan 10 Javascript
vue双向数据绑定原理探究(附demo)
Jan 17 Javascript
js封装成插件_Canvas统计图插件编写实例
Sep 12 Javascript
vue 中动态绑定class 和 style的方法代码详解
Jun 01 Javascript
vue-lazyload使用总结(推荐)
Nov 01 Javascript
vue路由缓存的几种实现方式小结
Feb 02 Javascript
vue插槽slot的简单理解与用法实例分析
Mar 14 Javascript
vue-router中hash模式与history模式的区别
Jun 23 Vue.js
jquery多选项卡效果实例代码(附效果图)
Mar 23 #Javascript
Jquery实现带动画效果的经典二级导航菜单
Mar 22 #Javascript
关于div自适应高度/左右高度自适应一致的js代码
Mar 22 #Javascript
JS实现淘宝幻灯片效果的实现方法
Mar 22 #Javascript
jQuery+CSS实现菜单滑动伸展收缩(仿淘宝)
Mar 22 #Javascript
使用JavaScript构建JSON格式字符串实现步骤
Mar 22 #Javascript
鼠标滚轮控制网页横向移动实现思路
Mar 22 #Javascript
You might like
PHP 字符串加密函数(在指定时间内加密还原字符串,超时无法还原)
2010/04/28 PHP
php 字符串中的\n换行符无效、不能换行的解决方法
2014/04/02 PHP
php集成动态口令认证
2016/07/21 PHP
thinkphp3.2同时连接两个数据库的简单方法
2019/08/13 PHP
Laravel中validation验证 返回中文提示 全局设置的方法
2019/09/29 PHP
laravel 根据不同组织加载不同视图的实现
2019/10/14 PHP
JavaScript 获取事件对象的注意点
2009/07/29 Javascript
js实现点击注册按钮开始读秒倒计时的小例子
2013/05/11 Javascript
javascript字符串替换及字符串分割示例代码
2013/12/12 Javascript
jQuery插件Elastislide实现响应式的焦点图无缝滚动切换特效
2015/04/12 Javascript
jQuery实现单击弹出Div层窗口效果(可关闭可拖动)
2015/09/19 Javascript
javascript中eval解析JSON字符串
2016/02/27 Javascript
Bootstrap轮播图学习使用
2017/02/10 Javascript
深入理解Node中的buffer模块
2017/06/03 Javascript
Vue2.0基于vue-cli+webpack Vuex的用法(实例讲解)
2017/09/15 Javascript
JS脚本加载后执行相应回调函数的操作方法
2018/02/28 Javascript
详解vuex结合localstorage动态监听storage的变化
2018/05/03 Javascript
详解Vscode中使用Eslint终极配置大全
2019/11/08 Javascript
小程序接口的promise化的实现方法
2019/12/11 Javascript
vue 使用rules对表单字段进行校验的步骤
2020/12/25 Vue.js
python调用tcpdump抓包过滤的方法
2018/07/18 Python
python 获取页面表格数据存放到csv中的方法
2018/12/26 Python
华为校园招聘上机笔试题 扑克牌大小(python)
2020/04/22 Python
python opencv实现gif图片分解的示例代码
2019/12/13 Python
python-OpenCV 实现将数组转换成灰度图和彩图
2020/01/09 Python
加拿大百叶窗和窗帘定制网站:Blinds
2017/01/30 全球购物
英国水族馆和池塘用品购物网站:Warehouse Aquatics
2019/08/29 全球购物
编码转换,怎样实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串
2014/01/07 面试题
计算机专业毕业生的自我评价
2013/11/18 职场文书
咖啡店自主创业商业计划书
2014/01/22 职场文书
弘扬焦裕禄精神走群众路线思想汇报
2014/09/12 职场文书
解除劳动合同协议书(样本)
2014/10/02 职场文书
爱心助学感谢信
2015/01/21 职场文书
初中毕业生自我评价
2015/03/02 职场文书
幼儿园音乐教学反思
2016/02/18 职场文书
MySql子查询IN的执行和优化的实现
2021/08/02 MySQL