美文网首页
「JS」案例 · 数值转换

「JS」案例 · 数值转换

作者: DebraJohn | 来源:发表于2018-07-07 17:30 被阅读0次
    var a="abc123";
    function add(){
        a++;
    }
    add();
    document.write(a);
    

    以上代码的输出结果为:NaN

    知识点1:递增递减运算符

    a++
    可以理解为a=a+1
    而在+1之前先将a本身的值返回

    ++a
    先+1,再将a的值返回

    知识点2:数值转换

    因为递增递减运算符是针对于Number数字类型的
    于是在运行之前,会先把类型转换为数字,Number()
    分为以下几种情况:

    1. 如果是Boolean值,true转换为1,false转换为0
    2. 如果是数字值,直接返回
    3. 如果是null,返回0
    4. 如果是undefined,返回NaN
    5. 如果是字符串,又分为几种情况
      1. 如果字符串值包含数字,则转换为十进制的数字,如"123"转换为123,"0123"也转换为123。
      2. 如果字符串包含有效浮点格式,转换为对应的浮点数值。
      3. 如果字符串包含有效十六进制格式,转换为相同大小的十进制整数值。
      4. 如果字符串为空,转换为0。
      5. 如果字符串中包含除上述格式以外的字符,转换为0。
    6. 如果是对象,则调用valueOf()方法,然后依照前面的规则转换。如果转换的结果是NaN,则调用toString()方法,然后再次按照上述规则转换。
    回到例子

    a++首先进行数值转换,将"abc123"进行Number()转换。
    结果为NaN,所以后面的运算也返回NaN。

    相关文章

      网友评论

          本文标题:「JS」案例 · 数值转换

          本文链接:https://www.haomeiwen.com/subject/durguftx.html