JavaScript的parseInt 取整使用


Posted in Javascript onMay 09, 2011

Java 也有 Integer.parseInt() 方法, 但是 JavaScript 的 parseInt 处理方式与 Java 等强整型语言不太一样, 所以经常有人因为对这个方法的使用不当而获得异常返回.

下面是一段 Java 代码, 用于将字符串 020 转为整型.

public class Test { 
public static void main(String args[]) throws Exception { 
String str = "020"; 
System.out.println(Integer.parseInt(str)); 
} 
}

输出结果是 20

下面是一段 JavaScript 代码, 同样是将字符串 020 转为整型.

var str = "020"; 
var num = parseInt(str); 
alert(num);

输出结果是 16

为什么呢?
无论是 Java 还是 JavaScript, parseInt 方法都有两个参数, 第一个参数就是要转换的对象, 第二个参数是进制基数, 可以是 2, 8, 10, 16, 默认以 10 进制处理. 但在 JavaScript 中, 0 开始的数被认为使用 8 进制处理, 0x 的数被认为是用 16 进制来处理. 所以上面的 JavaScript 代码计算错误了.

影响大吗?
大! 很大! 因为这个经常用于计算价钱, 一旦价格错误, 对用户来说, 这是误导, 而一个好的网站不应该出现这种误导用户的. 下面的 DEMO 中, 没有指定进制. 大家可以在数量框中输入一个以 0 开头的数字, 在点击计算按钮, 算出来的数值将比预想中的小一些, 或者小很多 (如: 8 进制中没有 019 这样的数值, 所以数值变成了 1, 9 被忽略掉).
没有为 parseInt 函数指定进制的 DEMO

如何修改?
前面说过, 有两个参数, 第二个参数可以指定计算使用的进制.

parseInt(num, radix);

所以我们可以将前面有问题的那段 JavaScript 代码改写为下面的代码.
var str = "020"; 
var num = parseInt(str, 10); 
alert(num);

这样处理的话, 我们再重写一些前面的 DEMO, 如下:
为 parseInt 函数指定进制为 10 的 DEMO
记住了, 在 JavaScript 上使用 parseInt 方法时要带上进制参数.
Javascript 相关文章推荐
FF火狐下获取一个元素同类型的相邻元素实现代码
Dec 15 Javascript
jquery对table中各数据的增加、保存、删除操作示例
May 14 Javascript
js监听鼠标事件控制textarea输入字符串的个数
Sep 29 Javascript
JavaScript中的Math.LN2属性用法详解
Jun 12 Javascript
微信小程序 WXML、WXSS 和JS介绍及详解
Oct 08 Javascript
AngularJS使用ng-repeat遍历二维数组元素的方法详解
Nov 11 Javascript
微信小程序实现自上而下字幕滚动
Jul 14 Javascript
微信小程序动态生成二维码的实现代码
Jul 25 Javascript
详解关于微信setData回调函数中的坑
Feb 18 Javascript
JS数组方法reduce的用法实例分析
Mar 03 Javascript
JS addEventListener()和attachEvent()方法实现注册事件
Jan 11 Javascript
JavaScript实现H5接金币功能(实例代码)
Feb 22 Javascript
实现变速回到顶部的JavaScript代码
May 09 #Javascript
Javascript 倒计时源代码.(时.分.秒) 详细注释版
May 09 #Javascript
Chrome Form多次提交表单问题的解决方法
May 09 #Javascript
JQuery将文本转化成JSON对象需要注意的问题
May 09 #Javascript
通过Jscript中@cc_on 语句识别IE浏览器及版本的代码
May 07 #Javascript
基于JQUERY的两个ListBox子项互相调整的实现代码
May 07 #Javascript
基于jquery的lazy loader插件实现图片的延迟加载[简单使用]
May 07 #Javascript
You might like
win7 64位系统 配置php最新版开发环境(php+Apache+mysql)
2014/08/15 PHP
js防止表单重复提交的两种方法
2013/09/30 Javascript
setInterval()和setTimeout()的用法和区别示例介绍
2013/11/17 Javascript
jQuery的DOM操作之删除节点示例
2014/01/03 Javascript
javaScript 页面自动加载事件详解
2014/02/10 Javascript
iframe实用操作锦集
2014/04/22 Javascript
JavaScript中的比较操作符>、=、
2014/12/31 Javascript
angularJS中$apply()方法详解
2015/01/07 Javascript
45个JavaScript编程注意事项、技巧大全
2015/02/11 Javascript
基于javascript实现tab选项卡切换特效调试笔记
2016/03/30 Javascript
详解JavaScript中Hash Map映射结构的实现
2016/05/21 Javascript
jQuery中ajax错误调试分析
2016/12/01 Javascript
从零学习node.js之简易的网络爬虫(四)
2017/02/22 Javascript
nodeJs实现基于连接池连接mysql的方法示例
2018/02/10 NodeJs
vue-cli2.0转3.0之项目搭建的详细步骤
2018/12/11 Javascript
node.js实现上传文件功能
2019/07/15 Javascript
JS插件amCharts实现绘制柱形图默认显示数值功能示例
2019/11/26 Javascript
原生JS实现微信通讯录
2020/06/18 Javascript
js实现全选和全不选
2020/07/28 Javascript
分享一个常用的Python模拟登陆类
2015/03/29 Python
Python Web框架Tornado运行和部署
2020/10/19 Python
python2.7读取文件夹下所有文件名称及内容的方法
2018/02/24 Python
python 实现将txt文件多行合并为一行并将中间的空格去掉方法
2018/12/20 Python
python 列表推导式使用详解
2019/08/29 Python
python如果快速判断数字奇数偶数
2019/11/13 Python
如何修复使用 Python ORM 工具 SQLAlchemy 时的常见陷阱
2019/11/19 Python
TensorFlow实现批量归一化操作的示例
2020/04/22 Python
查看keras的默认backend实现方式
2020/06/19 Python
python字典的值可以修改吗
2020/06/29 Python
详解如何使用CSS3中的结构伪类选择器和伪元素选择器
2020/01/06 HTML / CSS
蜜蜂引路教学反思
2014/02/04 职场文书
法学求职信
2014/06/22 职场文书
美德少年事迹材料1000字
2014/08/21 职场文书
2016年母亲节寄语
2015/12/04 职场文书
2019大学生预备党员转正思想汇报
2019/06/21 职场文书
redis的list数据类型相关命令介绍及使用
2022/01/18 Redis