您的位置是:网站首页>Javascript编程Javascript编程

深入了解JavaScript中的null

少儿编程网2020-11-13 13:31:35Javascript编程 人已围观 来源:少儿编程 -用户投稿

简介推荐教程:《JavaScript视频教程》JavaScript有2种类型:基本类型(string,booleansnumber,symbol)和对象。对象是复杂的数据结构,JS中最简单的对象是普通对象:一组键和关联值:letmyObject={name:'前端小智'}但是在某些情况下

C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

推荐教程:《JavaScript视频教程》C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

JavaScript有2种类型:基本类型(string, booleans number, symbol)和对象。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

对象是复杂的数据结构,JS 中**简单的对象是普通对象:一组键和关联值:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

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

但是在某些情况下无法创建对象。 在这种情况下,JS 提供一个特殊值null —表示缺少对象。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

let myObject = null

在本文中,我们将了解到有关JavaScript中null的所有知识:它的含义,如何检测它,nullundefined之间的区别以及为什么使用null造成代码维护困难。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

1. null的概念C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

JS 规范说明了有关null的信息:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

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

例如,函数greetObject()创建对象,但是在无法创建对象时也可以返回nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

function greetObject(who) {
  if (!who) {
    return null;
  }
  return { message: `Hello, ${who}!` };
}

greetObject('Eric'); // => { message: 'Hello, Eric!' }
greetObject();       // => null

但是,在不带参数的情况下调用函数greetObject() 时,该函数返回null。 返回null是合理的,因为who参数没有值。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

2. 如何检查nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

检查null值的好方法是使用严格相等运算符:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

const missingObject = null;
const existingObject = { message: 'Hello!' };

missingObject  === null; // => true
existingObject === null; // => false

missingObject === null的结果为true,因为missingObject变量包含一个null 值。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

如果变量包含非空值(例如对象),则表达式existObject === null的计算结果为falseC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

2.1 null 是虚值C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

nullfalse0''undefinedNaN都是虚值。如果在条件语句中遇到虚值,那么 JS 将把虚值强制为falseC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

Boolean(null); // => false

if (null) {
  console.log('null is truthy')
} else {
  console.log('null is falsy')
}

2.2 typeof nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

typeof value运算符确定值的类型。 例如,typeof 15是'number'typeof {prop:'Value'}的计算结果是'object'C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

有趣的是,type null的结果是什么C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

typeof null; // => 'object'

为什么是'object'typoef nullobject是早期 JS 实现中的一个错误。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

要使用typeof运算符检测null值。 如前所述,使用严格等于运算符myVar === nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

如果我们想使用typeof运算符检查变量是否是对象,还需要排除null值:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

function isObject(object) {
  return typeof object === 'object' && object !== null;
}

isObject({ prop: 'Value' }); // => true
isObject(15);                // => false
isObject(null);              // => false

3. null 的陷阱C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

null经常会在我们认为该变量是对象的情况下意外出现。然后,如果从null中提取属性,JS 会抛出一个错误。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

再次使用greetObject() 函数,并尝试从返回的对象访问message属性:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

let who = '';

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

因为who变量是一个空字符串,所以该函数返回null。 从null访问message属性时,将引发TypeError错误。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

可以通过使用带有空值合并的可选链接来处理null:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

let who = ''

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

4. null 的替代方法C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

当无法构造对象时,我们通常的做法是返回null,但是这种做法有缺点。在执行堆栈中出现null时,刚必须进行检查。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

尝试避免返回 null 的做法:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

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

回到开始返回greeting对象的greetObject()函数。缺少参数时,可以返回一个默认对象,而不是返回nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

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

greetObject('Eric'); // => { message: 'Hello, Eric!' }
greetObject();       // => { message: 'Hello, Stranger!' }

或者抛出一个错误:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

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

这两种做法可以避免使用 nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

5. null vs undefinedC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

undefined是未初始化的变量或对象属性的值,undefined是未初始化的变量或对象属性的值。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

let myVariable;

myVariable; // => undefined

nullundefined之间的主要区别是,null表示丢失的对象,而undefined表示未初始化的状态。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

严格的相等运算符===区分nullundefined :C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

null === undefined // => false

而双等运算符==则认为nullundefined 相等C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

null == undefined // => true

我使用双等相等运算符检查变量是否为nullundefined:C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

function isEmpty(value) {
  return value == null;
}

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

6. 总结C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

null是JavaScript中的一个特殊值,表示丢失的对象,严格相等运算符确定变量是否为空:variable === nullC9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

typoef运算符对于确定变量的类型(number, string, boolean)很有用。 但是,如果为null,则typeof会产生误导:typeof null的值为'object'C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

nullundefined在某种程度上是等价的,但null表示缺少对象,而undefined未初始化状态。C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

更多编程相关知识,请访问:编程视频课程!!

以上就是深入了解JavaScript中的null的详细内容,更多请关注少儿编程网其它相关文章!C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

来源:php中文网C9y少儿编程网-Scratch_Python_教程_免费儿童编程学习平台


相关文章:

支持一下 ( )

深入了解JavaScript中的null

      匿名评论
    • 评论
    人参与,条评论
    深入了解JavaScript中的null

微信公众号

免费视频教程

先知道