网站地图    收藏   

主页 > 前端 > javascript >

js中parseInt数字,并求和用法详解

来源:自学PHP网    时间:2014-09-19 14:47 作者: 阅读:

[导读] parseInt() 函数可解析一个字符串,并返回一个整数,可时也可以对整数进行加减操作,下面我来介绍关于js中parseInt数字,并求和用法详解。...

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="求和" />

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论