一文让你彻底弄懂js中undefined和null的区别

一文让你彻底弄懂js中undefined和null的区别

在 JavaScript 中,undefined 和 null 都代表着一种空值。但是它们是有区别的,接下来我们就以具体实例为例逐一讲解它们之间的差异。

undefined

JavaScript 中,当一个变量被声明未赋值时,它的值就是 undefined。

let a;
console.log(a); // 输出 undefined

当访问一个不存在的对象属性时,它的值也是 undefined。

let obj = {
  name: 'Tom'
};
console.log(obj.age); // 输出 undefined

当函数没有传递参数时,调用函数参数的值就是 undefined。

function test(arg) {
  console.log(arg);
}
test(); // 输出 undefined

null

而 null 则代表着一个空对象指针,它代表着一个没有任何值的对象。

let a = null;
console.log(a); // 输出 null

区别

  • 空指针和未定义不同,因为空指针代表着某个变量指向一个空的对象,而未定义则代表这个变量根本不存在。

  • 当函数并未传递实参时,为了避免参数被隐式地转换为 undefined,适当考虑使用 null 。

function test(arg) {
  if (arg === null) {
    console.log('arg is null');
  }
  else if (arg === undefined) {
    console.log('arg is undefined');
  }
}
test(null); // 输出 arg is null
test(); // 输出 arg is undefined
  • 在 JavaScript 中,undefined 是原始值类型,而 null 是一个特殊的对象,所以在比较它们时要使用全等符号(===)来做比较。
console.log(null == undefined); // 输出 true
console.log(null === undefined); // 输出 false

总之,在 JavaScript 中,undefined 表示缺少某个值或变量,而 null 表示一个空的对象引用。在实际应用中,我们必须区分它们之间的差异,避免在使用时出现错误。

参考文献:MDN Web Docs

以上就是关于 JavaScript 中 undefined 和 null 的区别的详细讲解,希望能对您有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:一文让你彻底弄懂js中undefined和null的区别 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • javascript window.onerror事件学习新收获

    JavaScript Window.onerror事件学习新收获 什么是window.onerror事件? window.onerror 事件是在浏览器捕获到一个未处理的 JavaScript 错误时触发的事件。可以用来监听页面 JS 错误,并进行相应的处理,如记录错误信息、提示错误、上报错误等。 如何使用window.onerror事件? 在页面中添加以下…

    JavaScript 2023年5月28日
    00
  • JS中的变量作用域(console版)

    下面我将为你详细介绍“JS中的变量作用域(console版)”的攻略。 什么是变量作用域? 在JS中,变量的作用范围被称为变量作用域。简单来说,就是定义一个变量后,这个变量能够被访问的范围。JS中有全局作用域和局部作用域。全局作用域指的是在整个JS文件中都能够访问的变量,而局部作用域则指的是在函数中定义的变量,在函数外面是无法访问到的。 如何判断变量作用域?…

    JavaScript 2023年5月28日
    00
  • javascript闭包入门示例

    当我们在 JavaScript 中使用函数时,往往会遇到闭包的概念。那么什么是闭包呢?简单来说,闭包就是一个可以访问自由变量的函数。这个自由变量指的是函数内部定义的变量,在函数外也可以访问。下面我们通过两个示例来深入理解 JavaScript 闭包的概念和用法。 示例 1:基础闭包示例 function outerFunction() { var outer…

    JavaScript 2023年6月10日
    00
  • element-ui中导航组件menu的一个属性:default-active说明

    Element UI 是一款基于 Vue 2.0 的桌面端组件库,在其中导航组件 menu 是常用的菜单导航组件之一。该组件有一个属性:default-active,本文将详细讲解该属性。 属性说明 首先,我们来看该属性的官方说明。 default-active 属性可以用来设置默认激活的菜单项,它接收一个字符串类型的 index 值,默认值为 ”。 该属…

    JavaScript 2023年6月10日
    00
  • javascript遍历对象的五种方式实例代码

    当我们需要遍历JavaScript对象时,有许多种方法可供选择。下面是遍历对象的五种方式以及相应的代码示例: 1. for…in循环 for…in循环适用于遍历对象的属性。它将枚举对象的所有可枚举属性,包括原型链上的属性。 const person = {firstName: ‘John’, lastName: ‘Doe’, age: 30}; fo…

    JavaScript 2023年5月27日
    00
  • 工作中常用js功能汇总

    工作中常用js功能汇总 在工作中,我们经常会使用一些常用的 JavaScript 功能来实现不同的需求。本文将详细讲解一些常用的 JavaScript 功能,包括事件监听、DOM 操作、异步请求、正则表达式、日期时间操作等。 事件监听 事件监听是将 JavaScript 代码与 HTML 元素的交互相连的主要方式。添加事件监听器的方法是使用 addEvent…

    JavaScript 2023年5月18日
    00
  • JS获取屏幕高度的简单实现代码

    当我们需要获取浏览器窗口可视区域的高度时,可以使用JavaScript代码来实现。下面是获取屏幕高度的简单实现代码攻略: 1.通过window对象获取屏幕高度 我们可以通过window对象来获取浏览器窗口的高度。这里有一个简单的例子: var height = window.innerHeight; 其中,window.innerHeight属性用于获取浏览…

    JavaScript 2023年6月11日
    00
  • js数组的基本操作(很全自己整理的)

    下面是详细讲解“JS数组的基本操作”的完整攻略: JS数组的基本操作 数组(Array)是JS中常用的数据类型之一,它可以用来存储一组数据,而且支持很多常用的操作,比如增、删、改、查等。 定义数组 定义数组的方法有两种: 1. 字面量 可以使用方括号([])来定义数组,里面可以放入多个元素,它们之间用逗号隔开。 let arr = [1, ‘hello’, …

    JavaScript 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部