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实现拖拽效果
Feb 12 Javascript
JavaScript取得WEB安全颜色列表的方法
Jul 14 Javascript
微信小程序 教程之列表渲染
Oct 18 Javascript
前端实现文件的断点续传(前端文件提交+后端PHP文件接收)
Nov 04 Javascript
AngularJS用户选择器指令实例分析
Nov 04 Javascript
JS中BOM相关知识点总结(必看篇)
Nov 22 Javascript
zTree实现节点修改的实时刷新功能
Mar 20 Javascript
详解vue-cli与webpack结合如何处理静态资源
Sep 19 Javascript
vue mint-ui 实现省市区街道4级联动示例(仿淘宝京东收货地址4级联动)
Oct 16 Javascript
简单的Vue异步组件实例Demo
Dec 27 Javascript
微信小程序自定义底部导航带跳转功能
Nov 27 Javascript
jQuery+PHP+Ajax实现动态数字统计展示功能
Dec 25 jQuery
实现变速回到顶部的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中文分词系统SCWS安装和使用实例
2014/04/11 PHP
PHP截取指定图片大小的方法
2014/12/10 PHP
CI映射(加载)数据到view层的方法
2016/03/28 PHP
Yii模型操作之criteria查找数据库的方法
2016/07/15 PHP
PHP中字符与字节的区别及字符串与字节转换示例
2016/10/15 PHP
PHP crypt()函数的用法讲解
2019/02/15 PHP
javascript五图轮播切换实用版
2012/08/17 Javascript
angular.foreach 循环方法使用指南
2015/01/06 Javascript
JavaScript实现更改网页背景与字体颜色的方法
2015/02/02 Javascript
jQuery实现手机自定义弹出输入框
2016/06/13 Javascript
Javascript中document.referrer隐藏来源的方法
2017/01/16 Javascript
js学习心得_一个简单的动画库封装tween.js
2017/07/14 Javascript
详解JS数组Reduce()方法详解及高级技巧
2017/08/18 Javascript
详解基于DllPlugin和DllReferencePlugin的webpack构建优化
2018/06/28 Javascript
bootstrap Table实现合并相同行
2019/07/19 Javascript
vue将后台数据时间戳转换成日期格式
2019/07/31 Javascript
[40:05]LGD vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
使用 Python 获取 Linux 系统信息的代码
2014/07/13 Python
Vue的el-scrollbar实现自定义滚动
2018/05/29 Python
python中的二维列表实例详解
2018/06/19 Python
flask中的wtforms使用方法
2018/07/21 Python
Django 创建新App及其常用命令的实现方法
2019/08/04 Python
使用python执行shell脚本 并动态传参 及subprocess的使用详解
2020/03/06 Python
PyCharm2020最新激活码+激活码补丁(亲测最新版PyCharm2020.2激活成功)
2020/11/25 Python
CSS3 animation实现简易幻灯片轮播特效
2016/09/27 HTML / CSS
美国家喻户晓的保健品品牌:Vitamin World(维他命世界)
2016/08/19 全球购物
世界最大的海报和艺术印刷商店:AllPosters.com
2017/02/01 全球购物
会计电算化应届生自荐信
2014/02/25 职场文书
《分一分》教学反思
2014/04/13 职场文书
企业演讲稿范文大全
2014/05/20 职场文书
2014年后勤管理工作总结
2014/12/01 职场文书
民主评议党员个人总结
2015/02/13 职场文书
给校长的建议书范文
2015/09/14 职场文书
导游词之泉州崇武古城
2019/12/20 职场文书
浅谈Python数学建模之线性规划
2021/06/23 Python
MySQL配置主从服务器(一主多从)
2021/08/07 MySQL