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 相关文章推荐
js导出格式化的excel 实例方法
Jul 17 Javascript
Jquery实现仿腾讯微博发表广播
Nov 17 Javascript
jquery使用animate方法实现控制元素移动
Mar 27 Javascript
javascript中createElement的两种创建方式
May 14 Javascript
JavaScript和jquery获取父级元素、子级元素、兄弟元素的方法
Jun 05 Javascript
AngularJS 中文API参考手册
Jul 28 Javascript
Vue.js项目部署到服务器的详细步骤
Jul 17 Javascript
从零开始搭建一个react项目开发
Feb 09 Javascript
node和vue实现商城用户地址模块
Dec 05 Javascript
layui form.render('select', 'test2') 更新渲染的方法
Sep 27 Javascript
深入浅析golang zap 日志库使用(含文件切割、分级别存储和全局使用等)
Feb 19 Javascript
ReactRouter的实现方法
Jan 25 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+java实现自动新闻滚动窗口
2006/10/09 PHP
PHPExcel读取EXCEL中的图片并保存到本地的方法
2015/02/14 PHP
php获取、检查类名、函数名、方法名的函数方法
2015/06/25 PHP
PHP大文件切割上传并带进度条功能示例
2019/07/01 PHP
基于Jquery与WebMethod投票功能实现代码
2011/01/19 Javascript
简单的Jquery遮罩层代码实例
2013/11/14 Javascript
JQuery的$和其它JS发生冲突的快速解决方法
2014/01/24 Javascript
深入分析JSONP跨域的原理
2014/12/10 Javascript
14个有用的Jquery技巧分享
2015/01/08 Javascript
javascript 判断两个日期之差的示例代码
2015/09/05 Javascript
JS 实现倒计时数字时钟效果【附实例代码】
2016/03/30 Javascript
jQuery Validate设置onkeyup验证的实例代码
2016/12/09 Javascript
详解webpack+gulp实现自动构建部署
2017/06/29 Javascript
AngularJS路由删除#符号解决的办法
2017/09/28 Javascript
JS使用贪心算法解决找零问题示例
2017/11/27 Javascript
vue中引用swiper轮播插件的教程详解
2018/08/16 Javascript
mpvue项目中使用第三方UI组件库的方法
2018/09/30 Javascript
vue实现跨域的方法分析
2019/05/21 Javascript
vue单页应用的内存泄露定位和修复问题小结
2019/08/02 Javascript
JS实现随机抽选获奖者
2019/11/07 Javascript
vue实现点击按钮切换背景颜色的示例代码
2020/06/23 Javascript
[47:08]OG vs INfamous 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python数据结构之翻转链表
2017/02/25 Python
Python Tkinter模块实现时钟功能应用示例
2018/07/23 Python
利用Python将文本中的中英文分离方法
2018/10/31 Python
在python带权重的列表中随机取值的方法
2019/01/23 Python
Python字符串逆序的实现方法【一题多解】
2019/02/18 Python
python 实现12bit灰度图像映射到8bit显示的方法
2019/07/08 Python
python 爬虫百度地图的信息界面的实现方法
2019/10/27 Python
记一次Django响应超慢的解决过程
2020/09/17 Python
英国在线照明超市:Castlegate Lights
2019/10/30 全球购物
借条如何写
2015/05/26 职场文书
Django给表单添加honeypot验证增加安全性
2021/05/06 Python
68行Python代码实现带难度升级的贪吃蛇
2022/01/18 Python
Python内置类型集合set和frozenset的使用详解
2022/04/26 Python
SQL Server删除表中的重复数据
2022/05/25 SQL Server