• 简单方法判断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'
  • 相关阅读:
    机器学习笔记(四)---- 逻辑回归的多分类
    在modelarts上部署backend为TensorFlow的keras模型
    深度学习在其他领域的应用1:密码破解
    Reactive(2) 响应式流与制奶厂业务
    如何把图片变得炫酷多彩,Python教你这样实现!
    漫谈边缘计算(三):5G的好拍档
    机器学习笔记(三)---- 逻辑回归(二分类)
    华为云数据库携新品惊艳亮相2019华为全联接大会
    100 个网络基础知识普及,看完成半个网络高手
    最大流
  • 原文地址:https://www.cnblogs.com/communist/p/5952927.html
Copyright © 2020-2023  润新知