javascript的parseInt函数,大家都知道是干啥的
但你知道
parseInt("07") 返回多少 ?
parseInt("08") 又返回多少 ?
正确答案是
parseInt("07") 返回8
parseInt("08") 返回0
你知道问题在哪?
其实,这个问题可能大家都没想过吧。
用javascript的parseInt函数时,
parseInt("08")或者parseInt("09")返回的居然是0,
而parseInt("01")...parseInt("07")都是正确的。
为什么这样呢?
一开始很难理解,后来发现出现这个问题的原因是当在前面有"0"时,
javascript的debugger会认为这是一个八进制数,
而"08"和"09"不是一个合法的八进制数,
所以导致了那个问题,但是parseFloat不会存在这个问题。
javascript参考中parseInt()函数是如此描述:
parseInt 方法
返回由字符串转换得到的整数。将字符串转换成整型。
parseInt(numString, [radix])
parseInt的参数radix:
可选项。在 2 和 36 之间的表示 numString 所保存数字的进制的值。如果没有提供,则前缀为 '0x' 的字符串被当作十六进制,前缀为 '0' 的字符串被当作八进制。所有其它字符串都被当作是十进制的。
因此,如果使用parseInt("08",10)或者parseInt("09",10),
通知javascript解释器使用十进制来解析就可以得到你要的数字。
附:
代码如下 | 复制代码 |
parseInt("abc") // 返回 NaN。 parseInt("12abc") // 返回 12。 |
例
代码如下 | 复制代码 |
<title>用parseInt解析数字,并求和</title> <style> body{font:12px/1.5 arial;text-align:center;} .f-text{width:50px;border:1px solid #ccc;background:#f0f0f0;font-family:inherit;padding:3px;} span{color:green;padding-right:10px;font-weight:700;} strong{padding:0 10px;} </style> <script type="text/javascript"> window.onload = function () { var aInput = document.getElementsByTagName("input"); var aSpan = document.getElementsByTagName("span")[0]; var i = 0; for (i = 0; i < aInput.length - 1; i++) { aInput[i].onkeyup = function () { this.value = this.value.replace(/[^d]/,"") } } aInput[2].onclick = function () { (aInput[0].value == "" || aInput[1].value == "") ? alert("请输入数字!") : aSpan.innerHTML = parseInt(aInput[0].value) + parseInt(aInput[1].value); } }; </script> </head> <body> <input type="text" class="f-text" /><strong>+</strong><input type="text" class="f-text" /><strong>=</strong><span>?</span><input type="button" value="求和" /> |
时间: 2024-10-31 12:07:29