zoukankan      html  css  js  c++  java
  • Javascript 中的false、0、null、undefined和空字符串对象

    在Javascript中,我们经常会接触到题目中提到的这5个比较特别的对象——false、0、空字符串、null和undefined。这几个对象很容易用错,因此在使用时必须得小心。

    类型检测

    我们下来看看他们的类型分别是什么:

    1. <script type="text/javascript"
    2.     alert(typeof(false) === 'boolean'); 
    3.     alert(typeof(0) === 'number'); 
    4.     alert(typeof("") === 'string'); 
    5.     alert(typeof(null) === 'object'); 
    6.     alert(typeof undefined === 'undefined');     
    7. </script
    <script type="text/javascript">
        alert(typeof(false) === 'boolean');
        alert(typeof(0) === 'number');
        alert(typeof("") === 'string');
        alert(typeof(null) === 'object');
        alert(typeof undefined === 'undefined');    
    </script>
    
    

    运行上述代码,弹出的对话框应该显示的都是true。也就是说,false是布尔类型对象,0是数字类型对象,空字符串是字符串类型对象,null是object对象,undefined类型还是undefined。

    互等性

    当你用==操作符将false对象和其他对象进行比较的时候,你会发现,只有0和空字符串等于false;undefined和null对象并不等于false对象,而null和undefined是相等的

    1. <script type="text/javascript"
    2.     alert(false == undefined); 
    3.     alert(false == null); 
    4.     alert(false == 0); 
    5.     alert(false == ""); 
    6.     alert(null == undefined); 
    7. </script
    <script type="text/javascript">
        alert(false == undefined);
        alert(false == null);
        alert(false == 0);
        alert(false == "");
        alert(null == undefined);
    </script>

    我们可以把0、空字符串和false归为一类,称为“假值”;把null和undefined归为一类,称为“空值”。假值还算一个有效的对象,因此可以对其使用toString等类型相关的方法,而空值则不行。下面的代码将会抛出异常:

    1. <script type="text/javascript"
    2.     alert(false.toString());    // "false" 
    3.     alert("".charAt(0));        // "" 
    4.     alert((0).toExponential(10));  // 0.0000000e+0 
    5.     alert(undefined.toString());    // throw exception "undefined has no properties" 
    6.     alert(null.toString());         // "null has no properties" 
    7. </script
    <script type="text/javascript">
        alert(false.toString());    // "false"
        alert("".charAt(0));        // ""
        alert((0).toExponential(10));  // 0.0000000e+0
        alert(undefined.toString());    // throw exception "undefined has no properties"
        alert(null.toString());         // "null has no properties"
    </script>

    字符串表示

    虽然空值不能调用toString方法,但是却可以使用String构造函数进行构造。像decodeURI这样的函数,如果传入的是undefined或者null,返回的是“undefined”和“null”字符串。这点很容易用错。

    1. <script type="text/javascript"
    2.     alert(String(false));    // "false" 
    3.     alert(String(""));        // "" 
    4.     alert(String(0));  // 0.0000000e+0 
    5.     alert(String(undefined));    // "undefined" 
    6.     alert(String(null));             // "null" 
    7.      
    8.     alert(decodeURI(undefined));// "undefined" 
    9.     alert(decodeURI(null));// "null" 
    10. </script
    <script type="text/javascript">
        alert(String(false));    // "false"
        alert(String(""));        // ""
        alert(String(0));  // 0.0000000e+0
        alert(String(undefined));    // "undefined"
        alert(String(null));             // "null"
        
        alert(decodeURI(undefined));// "undefined"
        alert(decodeURI(null));// "null"
    </script>

    假值和空值作为if条件分支

    假值和空值有一个共性,那就是在作为if的条件分支时,均被视为false;应用“!”操作之后得到的均为true。如下示例代码:

    1. <script type="text/javascript"
    2.     var ar = [undefined,false,0,"",null]; 
    3.     for(var i = 0,len = ar.length; i < len; i++){ 
    4.         if(ar[i]){ 
    5.             alert("你不应该看到此对话框!"); 
    6.         } 
    7.     } 
    8. </script
    <script type="text/javascript">
        var ar = [undefined,false,0,"",null];
        for(var i = 0,len = ar.length; i < len; i++){
            if(ar[i]){
                alert("你不应该看到此对话框!");
            }
        }
    </script>

    这是因为,这几个对象均被视为各自类型中的无效值或空值。因此if分支中这些对象均被视为false对待。

    null和undefined的区别

    这两个空值的区别也是容易混淆的。

    undefined和null对象无非是两个特殊对象,undefined表示无效对象,null表示空对象。如果变量显式或者隐式(由Javascript引擎进行赋值)地被赋予了undefined,那么代表了此变量未被定义,如果被赋予null值,则代表此变量被初始化为空值。

    在Javascript中,变量是通过var声明,=赋值符进行定义(初始化变量所指向的对象)。当然,如果声明一个全局变量(作为window属性)可以不使用var关键字。变量可以在声明的同时进行定义。

    1. <script type="text/javascript"
    2.     var undefinedVariable,nullVariable = null; 
    3.     alert(undefinedVariable); // "undefined" 
    4.     alert(window.undefinedVariable);        // "undefined" 
    5.     alert(window.abcd);        // "undefined" 
    6.     alert(nullVariable);          // "null" 
    7.     alert(abcd);                    // throw exception "abcd is not defined" 
    8. </script>  
    <script type="text/javascript">
        var undefinedVariable,nullVariable = null;
        alert(undefinedVariable); // "undefined"
        alert(window.undefinedVariable);        // "undefined"
        alert(window.abcd);        // "undefined"
        alert(nullVariable);          // "null"
        alert(abcd);                    // throw exception "abcd is not defined"
    </script> 

    其实,变量如果声明了但是没有初始化,那么Javascript引擎会将此变量自动指向undefined对象。

    这里需要注意,我们在上面引用window.abcd时,弹出的是undefined;而直接引用abcd变量时,却抛出了一个异常。这是由于Javascript引擎对于没有显式指定对象链的变量,会尝试从最近的作用域开始查找变量,查找失败,则退到父级作用链进行查找。如果均查找失败,则抛出“变量未定义”的异常。

    这两个值在进行数字运算的时候也有不同。

    1. <script type="text/javascript"
    2.     alert(1+undefined);    // "NaN" 
    3.     alert(1+null);             // "1" 
    4. </script
    <script type="text/javascript">
        alert(1+undefined);    // "NaN"
        alert(1+null);             // "1"
    </script>

    从null和undefined的意义上来说,这是很好理解的。

  • 相关阅读:
    《应用Yii1.1和PHP5进行敏捷Web开发》学习笔记(转)
    YII 小模块功能
    Netbeans代码配色主题大搜集
    opensuse 启动巨慢 解决方法 90s多
    opensuse 安装 网易云音乐 rpm netease music
    linux qq rpm deb opensuse
    openSUSE 安装 alien
    第一行代码 Android 第2版
    Android Studio AVD 虚拟机 联网 失败
    docker error during connect: Get http://%2F%2F.%2Fpipe%2Fdocker_engine/v1.29/containers/json: open //./pipe/docker_engine: The system cannot find the file specified. In the default daemon configuratio
  • 原文地址:https://www.cnblogs.com/thisway/p/5138724.html
Copyright © 2011-2022 走看看