JavaScript 的 parseInt 取整
2015-06-16 18:24
543 查看
http://www.neoease.com/javascript-get-integer-via-parseint/
JavaScript 是弱类型语言, 为了保证数值的有效性, 在处理数值的时候, 我们可以对数值字符串进行强行转换. 如 parseInt 取整和 parseFloat 取浮点数.
Java 也有 Integer.parseInt() 方法, 但是 JavaScript 的 parseInt 处理方式与 Java 等强整型语言不太一样, 所以经常有人因为对这个方法的使用不当而获得异常返回.
下面是一段 Java 代码, 用于将字符串 020 转为整型.
输出结果是 20
下面是一段 JavaScript 代码, 同样是将字符串 020 转为整型.
输出结果是 16
没有为 parseInt 函数指定进制的 DEMO
所以我们可以将前面有问题的那段 JavaScript 代码改写为下面的代码.
这样处理的话, 我们再重写一些前面的 DEMO, 如下:
为 parseInt 函数指定进制为 10 的 DEMO
记住了, 在 JavaScript 上使用 parseInt 方法时要带上进制参数.
--------------------------
http://www.w3school.com.cn/jsref/jsref_parseInt.asp
举例,如果 string 以 "0x" 开头,parseInt() 会把 string 的其余部分解析为十六进制的整数。如果 string 以 0 开头,那么 ECMAScript v3 允许 parseInt() 的一个实现把其后的字符解析为八进制或十六进制的数字。如果 string 以 1 ~ 9 的数字开头,parseInt() 将把它解析为十进制的整数。
注释:开头和结尾的空格是允许的。
提示:如果字符串的第一个字符不能被转换为数字,那么 parseFloat() 会返回 NaN。
JavaScript 全局对象
JavaScript 是弱类型语言, 为了保证数值的有效性, 在处理数值的时候, 我们可以对数值字符串进行强行转换. 如 parseInt 取整和 parseFloat 取浮点数.
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)); } } |
下面是一段 JavaScript 代码, 同样是将字符串 020 转为整型.
var str = "020"; var num = parseInt(str); alert(num); |
为什么呢?
无论是 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); |
var str = "020"; var num = parseInt(str, 10); alert(num); |
为 parseInt 函数指定进制为 10 的 DEMO
记住了, 在 JavaScript 上使用 parseInt 方法时要带上进制参数.
--------------------------
http://www.w3school.com.cn/jsref/jsref_parseInt.asp
JavaScript parseInt() 函数
JavaScript 全局对象定义和用法
parseInt() 函数可解析一个字符串,并返回一个整数。语法
parseInt(string, radix)
参数 | 描述 |
---|---|
string | 必需。要被解析的字符串。 |
radix | 可选。表示要解析的数字的基数。该值介于 2 ~ 36 之间。 如果省略该参数或其值为 0,则数字将以 10 为基础来解析。如果它以 “0x” 或 “0X” 开头,将以 16 为基数。 如果该参数小于 2 或者大于 36,则 parseInt() 将返回 NaN。 |
返回值
返回解析后的数字。说明
当参数 radix 的值为 0,或没有设置该参数时,parseInt() 会根据 string 来判断数字的基数。举例,如果 string 以 "0x" 开头,parseInt() 会把 string 的其余部分解析为十六进制的整数。如果 string 以 0 开头,那么 ECMAScript v3 允许 parseInt() 的一个实现把其后的字符解析为八进制或十六进制的数字。如果 string 以 1 ~ 9 的数字开头,parseInt() 将把它解析为十进制的整数。
提示和注释
注释:只有字符串中的第一个数字会被返回。注释:开头和结尾的空格是允许的。
提示:如果字符串的第一个字符不能被转换为数字,那么 parseFloat() 会返回 NaN。
实例
在本例中,我们将使用 parseInt() 来解析不同的字符串:parseInt("10"); //返回 10 parseInt("19",10); //返回 19 (10+9) parseInt("11",2); //返回 3 (2+1) parseInt("17",8); //返回 15 (8+7) parseInt("1f",16); //返回 31 (16+15) parseInt("010"); //未定:返回 10 或 8
TIY
parseInt()如何使用 parseInt() 来解析不同的字符串。JavaScript 全局对象
相关文章推荐
- jsp防盗链代码
- js输出数组中不同项的个数
- 一道题目理解js中变量在作用域链与原型链中的查找顺序
- JavaScript Prototype
- js可以解码utf-8编码,我一直以为decodeURIComponent只能解码16进制呢,原理???
- Java抓取网页数据(原来的页面+Javascript返回数据)
- POJ 1847 dijstra算法
- JavaScript——数组常用数组方法汇总
- Javascript-DOM
- js代码获取网页的一些参数
- JSON数组转换为List对象
- 判断JSON数组参数值是否为空
- 为js的数组添加contains方法,方便使用
- 【Extjs】 checkboxmodel 中事件处理
- js中(function(){…})()立即执行函数写法理解
- SBJson的使用
- JS中将时间戳转格式
- 常用js函数--个人项目总结
- javascript设置canvas宽高
- Atitit.js获取上传文件全路径