关于js的parseInt方法自动计算错误

<script type="text/javascript">
	function test(){
					alert(parseInt("01")-parseInt("03"));
					alert(parseInt("02")-parseInt("03"));
					alert(parseInt("03")-parseInt("03"));
					alert(parseInt("04")-parseInt("03"));
					alert(parseInt("05")-parseInt("03"));
					alert(parseInt("06")-parseInt("03"));
					alert(parseInt("07")-parseInt("03"));
					alert(parseInt("08")-parseInt("03"));//结果为负
					alert(parseInt("09")-parseInt("03"));//结果为负
					alert(parseInt("10")-parseInt("03"));
					alert(parseInt("11")-parseInt("03"));
					alert(parseInt("12")-parseInt("03"));
	}

</script>
</head>
  <body>

  <a href="javascript:test()">点击</a>

  </body>
</html>

  

 

   弹出结果依次为:-2  -1  0  1  2  3  4  -3  -3  7   8   9

  

查找了JS的文档后发现这个问题发生的原因是前面的"0",parseInt方法有一个可选参数来表示数字的进制,以"0"作为首字符的字符串会被JS识别为八进制数并将没有指定数字进制参数的参数值默认为8,从而以八进制来解析字符串,而"08"和"09"都不是合法的八进制数,所以被解析为0。</P>

实际上,这是个不注意细节引起的问题,显式设置进制参数的parseInt根本不会出现这个问题,parseInt("08",10)或parseInt("09",10)都能返回正确的数值。另外,parseFloat不会存在这个问题

 

转载于:https://my.oschina.net/u/2260184/blog/540565

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值