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 相关文章推荐
父子窗体间传递JSON格式的数据的代码
Dec 25 Javascript
Extjs4.0设置Ext.data.Store传参的请求方式(默认为GET)
Apr 02 Javascript
解析jQuery与其它js(Prototype)库兼容共存
Jul 04 Javascript
浅谈JSON.stringify()和JOSN.parse()方法的不同
Aug 29 Javascript
JavaScript 对象详细整理总结
Sep 29 Javascript
vue实现ToDoList简单实例
Feb 07 Javascript
jQuery实现拖动效果的实例代码
Jun 25 jQuery
Vue2.0如何发布项目实战
Jul 27 Javascript
Vue多种方法实现表头和首列固定的示例代码
Feb 02 Javascript
详解基于 Node.js 的轻量级云函数功能实现
Jul 08 Javascript
微信小程序实现分享商品海报功能
Sep 30 Javascript
vue 开发之路由配置方法详解
Dec 02 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
PHP下打开phpMyAdmin出现403错误的问题解决方法
2013/05/23 PHP
PHP 多任务秒级定时器的实现方法
2018/05/13 PHP
很酷的javascript loading效果代码
2008/06/18 Javascript
iframe 上下滚动条如何默认在下方实现原理
2012/12/10 Javascript
JavaScript点击按钮后弹出透明浮动层的方法
2015/05/11 Javascript
jQuery实现定时读取分析xml文件的方法
2015/07/16 Javascript
jQuery与getJson结合的用法实例
2015/08/07 Javascript
原生javascript实现图片无缝滚动效果
2016/02/12 Javascript
JavaScript学习笔记之数组随机排序
2016/03/23 Javascript
jQuery+css实现非常漂亮的水平导航菜单效果
2016/07/27 Javascript
微信小程序 canvas API详解及实例代码
2016/10/08 Javascript
JS中对数组元素进行增删改移的方法总结
2016/12/15 Javascript
JavaScript仿支付宝6位数字密码输入框
2016/12/29 Javascript
深入理解Node.js中的进程管理
2017/03/13 Javascript
NodeJS处理Express中异步错误
2017/03/26 NodeJs
Vue SSR 组件加载问题
2018/05/02 Javascript
javascript数组常见操作方法实例总结【连接、添加、删除、去重、排序等】
2019/06/13 Javascript
Vue动态加载图片在跨域时无法显示的问题及解决方法
2020/03/10 Javascript
JS sort方法基于数组对象属性值排序
2020/07/10 Javascript
Python 中Pickle库的使用详解
2018/02/24 Python
Python实现二维数组输出为图片
2018/04/03 Python
python得到qq句柄,并显示在前台的方法
2018/10/14 Python
numpy np.newaxis 的实用分享
2019/11/30 Python
pytorch制作自己的LMDB数据操作示例
2019/12/18 Python
TensorFlow自定义损失函数来预测商品销售量
2020/02/05 Python
用python打开摄像头并把图像传回qq邮箱(Pyinstaller打包)
2020/05/17 Python
单位在职证明范本
2014/01/09 职场文书
工作过失检讨书
2014/02/23 职场文书
协议书样本
2014/04/23 职场文书
劳动竞赛口号
2014/06/16 职场文书
法人授权委托书
2014/09/16 职场文书
乡镇党建工作汇报材料
2014/10/27 职场文书
防汛工作情况汇报
2014/10/28 职场文书
承诺书范本大全
2015/05/04 职场文书
2015法院个人工作总结范文
2015/05/25 职场文书
追悼会悼词大全
2015/06/23 职场文书