当前位置:网站首页>The difference between undefined and null in JS
The difference between undefined and null in JS
2022-08-01 11:04:00 【little snail game】
undefined 和 null 是 Javascript 中两种特殊的原始数据类型(Primary Type),它们都只有一个值,分别对应 undefined 和 null,这两种不同类型的值,即有着不同的语义和场景,但又表现出较为相似的行为.
一、JS 中的 null
1. 描述:
① 是 JavaScript 基本类型之一,特指对象的值未设置,是表示缺少的标识,指示变量未指向任何对象,把 null Look for has not yet been created object,也许更好理解;
② 是一个字面量,不像 undefined,它不是全局对象的一个属性;
③ 在布尔运算中被认为是 false;
④ Like any other object will never be JavaScript Implicitly assigned to the variable.
注:如果 JavaScript 预期某个位置应该是布尔值,会将该位置上现有的值自动转为布尔值.转换规则是除了下面六个值被转为 false,其他值都视为 true.
undefined
null
false
0
NaN
"" 或 ''(空字符串)
2. 典型用法:
(1) 作为函数的参数,Said the parameters of the function is empty.
(2) 作为对象原型链的终点.
二、JS 中的 undefined
1. 描述:
① 是 JavaScript 基本类型之一,表示 “缺少值”,就是此处应该有一个值,但是还没有定义;
② 是 JavaScript At run time to create a global variable,是全局对象的一个属性;
③ 在布尔运算中被认为是 false.
注:The global object and global variables,可参考 javascript 全局对象与全局变量
2. 典型用法:
(1)Variable is declared but no assignment,就等于 undefined.
(2)No value given a property of an object while,该属性的值为 undefined.
(3)调用函数过程中,Should provide the parameters of the provided no,该参数就等于 undefined.
(4)函数没有返回值时,默认返回 undefined.
三、JS 中的 undefined 和 null 的区别有:
1、相同点
1)都是原始类型的值,且保存在栈中变量本地
2)进行条件判断时,两者都是false:
console.log(undefined == null);//true ECMAScript认为undefined是null派生出来的,So define their values are the same
2、不同点
1)null是js的关键字,表示空值;undefined不是js的关键字,它是一个全局变量
2)null是Object的一个特殊值,如果一个Object为null,表示这个对象不是有效对象,null是一个不存在的对象的占位符;undefined是Globel的一个属性
null == undefined // true
null === undefined // false
实际上,undefined 值是派生自 null 值的,ECMAScript 标准规定对二者进行相等性测试要返回 true,可以理解为 null 和 undefined 都代表着无效的值,所以二者相等,But since the primitive data types are two different,所以不全等.
3)类型不一样:
typeof(null) // object
typeof(undefined) //undefined
console.log(typeof(null) === 'object')//true
console.log(typeof(undefied) === 'undefined')//true
4)In digital operation is converted to number 类型的值不同
在 null Performs arithmetic conversions on,Determine the value of 0
let a = 10 + null;
console.log(a); // 10
undefined 得出的结果为 NaN
let b = 10 + undefined;
console.log(b); // NaN
注:The add operation of implicit type conversion,可参考 “加号 +” 的运算原理(详细!!!)
四、Additional knowledge
数组进行相等比较是一个怪物,看下面的例子:
[] == '' // -> true
[] == 0 // -> true
[''] == '' // -> true
[0] == 0 // -> true
[0] == '' // -> false
[''] == 0 // -> true
[null] == '' // true
[null] == 0 // true
[undefined] == '' // true
[undefined] == 0 // true
[[]] == 0 // true
[[]] == '' // true
[[[[[[]]]]]] == '' // true
[[[[[[]]]]]] == 0 // true
[[[[[[ null ]]]]]] == 0 // true
[[[[[[ null ]]]]]] == '' // true
[[[[[[ undefined ]]]]]] == 0 // true
[[[[[[ undefined ]]]]]] == '' // true
个人理解:
以上例子可以理解为,在比较过程中, [] 、[null] 和 [undefined] 都隐式转换为 '';
For the most layer of the [] ,No matter how much the outer nested a [] ,Finally can be seen as only the layer a [] .
五、When the object creationnull.
let a = Object.create(null);
console.log("a", a); //{}
let b = null;
console.log("b", b);//null
六、null何时使用
When you need to release an object when the object assignment can be asnull,And then to release the object
var a = {
a:1,
b:2
};
a = null;
七、null、undefined是怎么产生的
产生null方式一:When accessing a noDOM节点时
console.log(document.getElementById(“#aaaaaaa”));//null
2、产生null方式二:ObjectThe prototype chain of the end:
console.log(Object.prototype.__proto__);//null
1、产生undefined方式一:声明了变量但未赋值:
var a;
console.log(a);//undefined
2、产生undefined方式二:The properties of the object without assignment:
var obj = {a:1};
console.log(obj.age)//undefined
3、产生undefined方式三:函数调用的时候,Under the condition of the parameters of the function does not provide:
function add(num){
console.log(num)
};
add();//undefined
4、产生undefined方式四:When the function without a return value:
var a = function(){};
console.log(a)//undefined
Some of the summary is not complete place,感谢指正!
边栏推荐
- Promise学习(四)异步编程的终极解决方案async + await:用同步的方式去写异步代码
- Generate certificates using KeyStore
- Promise learning (4) The ultimate solution for asynchronous programming async + await: write asynchronous code in a synchronous way
- 回归预测 | MATLAB实现TPA-LSTM(时间注意力注意力机制长短期记忆神经网络)多输入单输出
- STM32 personal notes - program run and fly
- STM32 Personal Notes - Embedded C Language Optimization
- 一篇文章,带你详细了解华为认证体系证书(1)
- 回归预测 | MATLAB实现RNN循环神经网络多输入单输出数据预测
- slice、splice、split傻傻分不清
- Mysql index related knowledge review one
猜你喜欢
随机推荐
Android 安全与防护策略
Promise学习(四)异步编程的终极解决方案async + await:用同步的方式去写异步代码
Browser shortcut keys
WPF 截图控件之绘制箭头(五)「仿微信」
mysql进阶(二十二)MySQL错误之Incorrect string value中文字符输入错误问题分析
RK3399 platform development series on introduction to (kernel) 1.52, printk function analysis - the function call will be closed
表达式引擎在转转平台的实践
Promise学习(一)Promise是什么?怎么用?回调地狱怎么解决?
js中常用追加元素的几种方法:append,appendTo,after,before,insertAfter,insertBefore,appendChild
July 31, 2022 -- Take your first steps with C# -- Use arrays and foreach statements in C# to store and iterate through sequences of data
Mini Program Graduation Works WeChat Food Recipes Mini Program Graduation Design Finished Products (2) Mini Program Functions
【随心笔记】假期快过去了,都干了点什么
ACL 2022 | 文本生成的相关前沿进展
Kaitian aPaaS mobile phone number empty number detection [Kaitian aPaaS battle]
pve 删除虚拟机「建议收藏」
PDMan-domestic free general database modeling tool (minimalist, beautiful)
MFC implementation road map navigation system
Dapr 与 NestJs ,实战编写一个 Pub & Sub 装饰器
Why Metropolis–Hastings Works
How to Steal $100 Million from the Perfect Smart Contract