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 相关文章推荐
$.each遍历对象、数组的属性值并进行处理
Jul 18 Javascript
js实现商城星星评分的效果
Dec 29 Javascript
jQuery简单实现彩色云标签效果示例
Aug 01 Javascript
老生常谈jquery中detach()和remove()的区别
Mar 02 Javascript
Bootstrap按钮组简单实现代码
Mar 06 Javascript
Ajax验证用户名或昵称是否已被注册
Apr 05 Javascript
vue非父子组件通信问题及解决方法
Jun 11 Javascript
对angularJs中2种自定义服务的实例讲解
Sep 30 Javascript
bootstrap table合并行数据并居中对齐效果
Oct 17 Javascript
理理Vue细节(推荐)
Apr 16 Javascript
javascript二维数组和对象的深拷贝与浅拷贝实例分析
Oct 26 Javascript
详解 javascript对象创建模式
Oct 30 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
自动把纯文本转换成Web页面的php代码
2009/08/27 PHP
php侧拉菜单 漂亮,可以向右或者向左展开,支持FF,IE
2009/10/15 PHP
PHP面向对象法则
2012/02/23 PHP
PHP 读取和编写 XML
2014/11/19 PHP
PHP的Socket网络编程入门指引
2015/08/11 PHP
js几个验证函数代码
2010/03/25 Javascript
jQuery 拖动层(在可视区域范围内)
2012/05/24 Javascript
javascript实现微信分享
2014/12/23 Javascript
在微信、支付宝、百度钱包实现点击返回按钮关闭当前页面和窗口的方法
2016/08/05 Javascript
JavaScript实现垂直向上无缝滚动特效代码
2016/11/23 Javascript
javascript实现去除HTML标签的方法
2016/12/26 Javascript
ES6入门教程之let和const命令详解
2017/05/17 Javascript
浅谈Angular HttpClient简单入门
2018/05/04 Javascript
三种Webpack打包方式(小结)
2018/09/19 Javascript
JS+html5实现异步上传图片显示上传文件进度条功能示例
2019/11/09 Javascript
Python中的random()方法的使用介绍
2015/05/15 Python
python数字图像处理实现直方图与均衡化
2018/05/04 Python
详解如何设置Python环境变量?
2019/05/13 Python
在Pandas中处理NaN值的方法
2019/06/25 Python
PyQt5+Pycharm安装和配置图文教程详解
2020/03/24 Python
pycharm工具连接mysql数据库失败问题
2020/04/01 Python
Python unittest如何生成HTMLTestRunner模块
2020/09/08 Python
Python利用socket模块开发简单的端口扫描工具的实现
2021/01/27 Python
pandas统计重复值次数的方法实现
2021/02/20 Python
自我鉴定书面格式
2014/01/13 职场文书
七一党建活动方案
2014/01/28 职场文书
快餐店的创业计划书范文
2014/01/29 职场文书
求职毕业生自荐书
2014/02/08 职场文书
大四优秀党员个人民主评议
2014/09/19 职场文书
党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
2015年食堂工作总结报告
2015/04/23 职场文书
学校艾滋病宣传活动总结
2015/05/09 职场文书
奖学金申请个人主要事迹材料
2015/11/04 职场文书
学前班教学反思
2016/02/24 职场文书
2019餐饮行业创业计划书!
2019/06/27 职场文书
html+css 实现简易导航栏功能
2021/04/07 HTML / CSS