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 相关文章推荐
javascript日期转换 时间戳转日期格式
Nov 05 Javascript
javascript 进阶篇1 正则表达式,cookie管理,userData
Mar 14 Javascript
jquery scrollTop方法根据滚动像素显示隐藏顶部导航条
May 27 Javascript
JavaScript函数中关于valueOf和toString的理解
Jun 14 Javascript
基于JS+Canves实现点击按钮水波纹效果
Sep 15 Javascript
js中数组插入、删除元素操作的方法
Feb 15 Javascript
AngularJS自定义指令实现面包屑功能完整实例
May 17 Javascript
vue过渡和animate.css结合使用详解
Jun 14 Javascript
解决vue页面刷新或者后退参数丢失的问题
Mar 13 Javascript
Node错误处理笔记之挖坑系列教程
Jun 05 Javascript
jquery获取元素到屏幕四周可视距离的方法
Sep 05 jQuery
JS实现数组去重,显示重复元素及个数的方法示例
Jan 21 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
11个PHP 分页脚本推荐
2011/08/15 PHP
探讨:array2xml和xml2array以及xml与array的互相转化
2013/06/24 PHP
Laravel 5 框架入门(四)完结篇
2015/04/09 PHP
如何使用PHP对网站验证码进行破解
2015/09/17 PHP
WordPress开发中短代码的实现及相关函数使用技巧
2016/01/05 PHP
php pdo oracle中文乱码的快速解决方法
2016/05/16 PHP
浅谈PHP的$_SERVER[SERVER_NAME]
2017/02/04 PHP
php中上传文件的的解决方案
2018/09/25 PHP
用js小类库获取浏览器的高度和宽度信息
2012/01/15 Javascript
21个值得收藏的Javascript技巧
2014/02/04 Javascript
jquery如何扑捉回车键触发的事件
2014/04/24 Javascript
JavaScript中常见的字符串操作函数及用法汇总
2015/05/04 Javascript
js表单中选择框值的获取及表单的序列化
2015/12/17 Javascript
Js的Array数组对象详解
2016/02/22 Javascript
Zero Clipboard实现浏览器复制到剪贴板的方法(多个复制按钮)
2016/03/24 Javascript
基于ExtJs在页面上window再调用Window的事件处理方法
2017/07/26 Javascript
BetterScroll 在移动端滚动场景的应用
2017/09/18 Javascript
angularjs实现简单的购物车功能
2017/09/21 Javascript
详解Ubuntu安装angular-cli遇到的坑
2018/09/08 Javascript
运用js实现图层拖拽的功能
2019/05/24 Javascript
JS实现的简单tab切换功能完整示例
2019/06/20 Javascript
[46:20]DOTA2-DPC中国联赛 正赛 PSG.LGD vs LBZS BO3 第二场 1月22日
2021/03/11 DOTA
python判断字符串是否包含子字符串的方法
2015/03/24 Python
Android基于TCP和URL协议的网络编程示例【附demo源码下载】
2018/01/23 Python
python opencv 直方图反向投影的方法
2018/02/24 Python
python制作填词游戏步骤详解
2019/05/05 Python
Pycharm简单使用教程(入门小结)
2019/07/04 Python
python用for循环求和的方法总结
2019/07/08 Python
python2和python3应该学哪个(python3.6与python3.7的选择)
2019/10/01 Python
wxpython+pymysql实现用户登陆功能
2019/11/19 Python
CSS3自定义滚动条样式 ::webkit-scrollbar的示例代码详解
2020/06/01 HTML / CSS
微软俄罗斯官方网站:Microsoft俄罗斯
2016/09/18 全球购物
文秘求职信范文
2014/04/10 职场文书
清明节网上祭英烈寄语2015
2015/03/04 职场文书
2015年外贸业务员工作总结范文
2015/05/23 职场文书
pytorch Dropout过拟合的操作
2021/05/27 Python