为什么NaN总是回归真实

时间:2015-03-10 15:32:29

标签: javascript nan parseint

在尝试验证JS中的数字字符串时遇到一些麻烦。 isNaN特别是行为不端。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>No Quirks!</title>
</head>
     <body>
        <h1>JavaScript Test</h1>

        <button onclick="myNanIsTrue()">Is it a number?</button>

        <p id="writeToHTML"></p>

        <script type="text/javascript">
        function myNanIsTrue() {
             var g = parseInt("40000000") + "<br />";
             var n = g;
             if (isNaN(g)){
                  g="moo!";
             }
             n += g + "<br />";
             document.getElementById("writeToHTML").innerHTML = n;
        }
        </script>
     </body>
</html>

尝试了几种这样的排列,但它似乎没有起作用。任何人都可以看到为什么这不起作用?

4 个答案:

答案 0 :(得分:3)

你写过:

var g = parseInt("40000000") + "<br />";

因此g是一个字符串:'40000000<br />'

parseInt("40000000")返回一个整数,但随后会向其追加一个字符串。 Javascript隐式地将数字转换为字符串,然后将它们连接起来。

字符串不是数字,因此isNaN(正确)返回true

答案 1 :(得分:1)

isNaN表示不是数字。这意味着它是一个检查您的变量是否不是数字的函数。 在您的情况下,您将<br>连接到您的整数,这会将您的整数转换为String。

/**
 * Created by jjansen on 10-Mar-15 4:38 PM.
 * stackoverflow
 */
var noNumber = parseInt("40000") + "<br>"; //this is now a String
var test = isNaN( noNumber ); //returns true
console.log("noNumber isNaN: " + test);
var number = parseInt("40000"); //this is a integer
test = isNaN( number );
console.log("number isNaN: " + test);

<小时/> 按f12并在控制台中复制此代码。您现在可以看到差异

答案 2 :(得分:0)

因为g是一个字符串(你要连接一个字符串,所以它将被转换为一个字符串)。

答案 3 :(得分:0)

在您的代码中,由于您构建它的方式,g的值始终是一个字符串。

每当您添加StringNumber时,您将通过连接这两个值来获得新的String

因此,在您的代码中,isNaN(g)将始终返回true