DMOZ中文网站分类目录-免费收录各类优秀网站的中文网站目录.
  • DmozDir.org
DMOZ目录快速登录入口-免费收录各类优秀网站的中文网站目录.由人工编辑,并提供网站分类目录检索及地区分类目录检索,是站长免费推广网站的有力平台!

JavaScript中关于null的一切

  • JavaScript中关于null的一切

  • 已被浏览: 46 次2020年10月26日    来源:  https://blog.csdn.net/qq449245884/article/details/109090237
  • 作者 Dmitri Pavluti 译者 前端小智 来源 dmitripavlutin 点赞再看 微信搜索 【大迁世界】 关注这个没有大厂背景 但有着一股向上积极心态人。本文 GitHub https://github.com/qq4

    作者:Dmitri Pavluti
    译者:前端小智
    来源:dmitripavlutin

    点赞再看,微信搜索 【大迁世界】 关注这个没有大厂背景,但有着一股向上积极心态人。本文 GitHub https://github.com/qq449245884/xiaozhi 上已经收录,文章的已分类,也整理了很多我的文档,和教程资料。

    送 5 本书,祝大家好运!

    JavaScript有2种类型:基本类型(string, booleans number, symbol)和对象。

    对象是复杂的数据结构,JS 中最简单的对象是普通对象:一组键和关联值:

    let myObject = {
      name: '前端小智'
    }
    

    但是在某些情况下无法创建对象。 在这种情况下,JS 提供一个特殊值null —表示缺少对象。

    let myObject = null
    

    在本文中,我们将了解到有关JavaScript中null的所有知识:它的含义,如何检测它,nullundefined之间的区别以及为什么使用null造成代码维护困难。

    1. null的概念

    JS 规范说明了有关null的信息:

    null 特指对象的值未设置,它是 JS 基本类型 之一,在布尔运算中被认为是falsy

    例如,函数greetObject()创建对象,但是在无法创建对象时也可以返回null

    function greetObject(who) {
      if (!who) {
        return null;
      }
      return { message: `Hello, ${who}!` };
    }
    
    greetObject('Eric'); // => { message: 'Hello, Eric!' }
    greetObject();       // => null
    

    但是,在不带参数的情况下调用函数greetObject()时,该函数返回null。 返回null是合理的,因为who参数没有值。

    2. 如何检查null

    检查null值的好方法是使用严格相等运算符:

    const missingObject = null;
    const existingObject = { message: 'Hello!' };
    
    missingObject  === null; // => true
    existingObject === null; // => false
    

    missingObject === null的结果为true,因为missingObject变量包含一个null 值。

    如果变量包含非空值(例如对象),则表达式existObject === null的计算结果为false

    2.1 null 是虚值

    nullfalse0''undefinedNaN都是虚值。如果在条件语句中遇到虚值,那么 JS 将把虚值强制为false

    Boolean(null); // => false
    
    if (null) {
      console.log('null is truthy')
    } else {
      console.log('null is falsy')
    }
    

    2.2 typeof null

    typeof value运算符确定值的类型。 例如,typeof 15是'number'typeof {prop:'Value'}的计算结果是'object'

    有趣的是,type null的结果是什么

    typeof null; // => 'object'
    

    为什么是'object'typoef nullobject是早期 JS 实现中的一个错误。

    要使用typeof运算符检测null值。 如前所述,使用严格等于运算符myVar === null

    如果我们想使用typeof运算符检查变量是否是对象,还需要排除null值:

    function isObject(object) {
      return typeof object === 'object' && object !== null;
    }
    
    isObject({ prop: 'Value' }); // => true
    isObject(15);                // => false
    isObject(null);              // => false
    

    3. null 的陷阱

    null经常会在我们认为该变量是对象的情况下意外出现。然后,如果从null中提取属性,JS 会抛出一个错误。

    再次使用greetObject()函数,并尝试从返回的对象访问message属性:

    let who = '';
    
    greetObject(who).message; 
    // throws "TypeError: greetObject() is null"
    

    因为who变量是一个空字符串,所以该函数返回null。 从null访问message属性时,将引发TypeError错误。

    可以通过使用带有空值合并的可选链接来处理null:

    let who = ''
    
    greetObject(who)?.message ?? 'Hello, Stranger!'
    // => 'Hello, Stranger!'
    

    4. null 的替代方法

    当无法构造对象时,我们通常的做法是返回null,但是这种做法有缺点。在执行堆栈中出现null时,刚必须进行检查。

    尝试避免返回 null 的做法:

    • 返回默认对象而不是null
    • 抛出错误而不是返回null

    回到开始返回greeting对象的greetObject()函数。缺少参数时,可以返回一个默认对象,而不是返回null

    function greetObject(who) {
      if (!who) {
        who = 'Stranger';
      }
      return { message: `Hello, ${who}!` };
    }
    
    greetObject('Eric'); // => { message: 'Hello, Eric!' }
    greetObject();       // => { message: 'Hello, Stranger!' }
    

    或者抛出一个错误:

    function greetObject(who) {
      if (!who) {
        throw new Error('"who" argument is missing');
      }
      return { message: `Hello, ${who}!` };
    }
    
    greetObject('Eric'); // => { message: 'Hello, Eric!' }
    greetObject();       // => throws an error
    

    这两种做法可以避免使用 null

    5. null vs undefined

    undefined是未初始化的变量或对象属性的值,undefined是未初始化的变量或对象属性的值。

    let myVariable;
    
    myVariable; // => undefined
    

    nullundefined之间的主要区别是,null表示丢失的对象,而undefined表示未初始化的状态。

    严格的相等运算符===区分nullundefined :

    null === undefined // => false
    

    而双等运算符==则认为nullundefined 相等

    null == undefined // => true
    

    我使用双等相等运算符检查变量是否为nullundefined:

    function isEmpty(value) {
      return value == null;
    }
    
    isEmpty(42);                // => false
    isEmpty({ prop: 'Value' }); // => false
    isEmpty(null);              // => true
    isEmpty(undefined);         // => true
    

    6. 总结

    null是JavaScript中的一个特殊值,表示丢失的对象,严格相等运算符确定变量是否为空:variable === null

    typoef运算符对于确定变量的类型(number, string, boolean)很有用。 但是,如果为null,则typeof会产生误导:typeof null的值为'object'

    nullundefined在某种程度上是等价的,但null表示缺少对象,而undefined未初始化状态。


    原文:https://dmitripavlutin.com/javascript-null/#comments

    代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug。

    交流

    文章每周持续更新,可以微信搜索 【大迁世界 】 第一时间阅读,回复 【福利】 有多份前端视频等着你,本文 GitHub https://github.com/qq449245884/xiaozhi 已经收录,欢迎Star。

    前端小智@大迁世界 CSDN认证博客专家 TypeScript ECMAScript 6 前端框架 我不是什么大牛,我其实想做的就是一个传播者。内容可能过于基础,但对于刚入门的人来说或许是一个窗口,一个解惑之窗。我要先坚持分享20年,大家来一起见证吧。
    以上信息来源于网络,如有侵权,请联系站长删除。

    TAG:JavaScript null

  • 上一篇:求伯君,一个你必须知道的程序员
  • 与“JavaScript中关于null的一切”相关的资讯
  • JavaScript中的链式调用
  • js怎么保留两位小数?
  • JavaScript中鼠标移入随机变换颜色
  • JavaScript用document.write()输出换行
  • JavaScript中为什么 0.1 + 0.2 != 0.3