• 简单方法判断JavaScript对象为null或者属性为空


     

    对已声明但未初始化的和未声明的变量执行typeof,都返回undefined,null表示一个空对象指针,typeof操作会返回object

    首先说下null与undefined区别:

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

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

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

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

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    var a = {};
    a.name = 'realwall';
    console.log(isEmpty(a)); //false
    console.log(isEmpty({})); //true
    console.log(isEmpty(null)); //true
     
    //注意参数为null时无语法错误哦,即虽然不能对null空指针对象添加属性,但可以使用for in 语句
     
      
    ?
    /*
    * 检测对象是否是空对象(不包含任何可读属性)。
    * 方法只既检测对象本身的属性,不检测从原型继承的属性。
    */
    function isOwnEmpty(obj)
    {
    for(var name in obj)
    {
    if(obj.hasOwnProperty(name))
    {
    return false;
    }
    }
    return true;
    };

    {}与null的区别:

    这个东西很重要。

    1
    2
    3
    4
    5
    6
    7
    var a = {};
    var b = null;
     
    a.name = 'realwall';
    b.name = 'jim'; //这里会报错,b为空指针对象,不能像普通对象一样直接添加属性。
    b = a;
    b.name = 'jim'; //此时 a 和 b 指向同一个对象。a.name, b.name 均为'jam'
  • 相关阅读:
    【BZOJ4448】【SCOI2015】情报传递
    【BZOJ2006】【NOI2010】超级钢琴
    NOIp2018模拟赛四十五~??
    【BZOJ4940】【YNOI2016】这是我自己的发明
    数据迁移—datax
    DG模拟GAP手动处理
    DG问题:ORA-16416: No viable Physical Standby switchover targets available
    管理和维护DG
    DG问题
    DG概念与机制
  • 原文地址:https://www.cnblogs.com/communist/p/5952927.html
Copyright © 2020-2023  润新知