zoukankan      html  css  js  c++  java
  • 判断JavaScript对象为null或者属性为空

    http://blog.csdn.net/yiluoak_47/article/details/7766760

    首先说下null与undefined区别:

    对已声明但未初始化的和未声明的变量执行typeof,都返回"undefined"。

    null表示一个空对象指针,typeof操作会返回"object"。

    一般不显式的把变量的值设置为undefined,但null相反,对于将要保存对象的变量,应明确的让该变量保存null值。

     1 var bj;
     2 alert(bj); 
     3 //"undefined"
     4 bj = null;
     6 alert(typeof bj); //"object"
     8 alert(bj == null);  //true
    11 bj = {};
    13 alert(bj == null);  //false
     

     下面两个函数是邓师兄给我的,感谢啊。

     1 /*
     2  *
     3  检测对象是否是空对象(不包含任何可读属性)。
     4  *
     5  方法既检测对象本身的属性,也检测从原型继承的属性(因此没有使hasOwnProperty)。
     6  */
     7 function isEmpty(obj)
     8 {
     9     for (var name in obj)
    11     {
    12         return false;
    13     }
    14     return true;
    15 };

     这里所说的空对象,到底是 {} 还是 null . 我写了一个测试用例。

     1 var a = {};
     3 a.name = 'realwall';
     5 console.log(isEmpty(a)); //false
     7 console.log(isEmpty({})); //true
     9 console.log(isEmpty(null)); //true
     //注意参数为null时无语法错误哦,即虽然不能对null空指针对象添加属性,但可以使用forin 语句。
    14   
    15 ?
    16 /*
    17  *
    18  检测对象是否是空对象(不包含任何可读属性)。
    19  *
    20  方法只既检测对象本身的属性,不检测从原型继承的属性。
    21  */
    22 function isOwnEmpty(obj)
    23 {
    24     for(var name
    25 in obj)
    26     {
    27         if(obj.hasOwnProperty(name))
    28         {
    29             return false;
    30         }
    31     }
    32     return true;
    33 };
    34  
    35 {}与null的区别:
    36 这个东西很重要。
    37 ?
    38 var a = {};
    40 var b = null;
    42  
    43 a.name = 'realwall';
    45 b.name = 'jim';
    47 //这里会报错,b为空指针对象,不能像普通对象一样直接添加属性。
    48 b = a;
    50 b.nameB= 'jim';
    52 //此时 a 和 b 指向同一个对象。a.name, b.name 均为'jam'
     
  • 相关阅读:
    刷皇室成员
    python 2.7中matplotlib的所有版本
    Linux命令使用时路径存在空格、特殊符号
    路径名太长导致无法读取文件
    谷歌浏览器打包插件
    Upload 上载新生
    Linux的终端(base),进入base环境
    Ubuntu16.04系统语言设置为中文以及搜狗输入法的安装
    R语言3D图导出矢量图有bug
    将本地文件复制到hadoop文件系统
  • 原文地址:https://www.cnblogs.com/chenchenluo/p/4345696.html
Copyright © 2011-2022 走看看