一.is not defined与undefined
之前没太注意is not defined和undefined有什么区别,每次都是简单的把两者理解为未定义,现在回过头来梳理js基础的时候才发现其中区别还是很鲜明的。
先从单纯的字面意思来理解一下(有道词典):
is not defined: 未定义
not defined: 未定义,没有定义,无法定义
&&
undefined: 不明确的
单从字面意思大体也能看出两者的区别:前者是没有定义,也就是说没有;后者是不明确的,也就是说不知道有没有定义.
not defined
看demo1:
console.log(a)
// 报错:a is not defined 终止运行
一个未定义 的变量是没有声明的变量,这样的变量在使用时会直接报错误。
undefined
一个定义了但未赋值的 变量
demo2:
var a
console.log(a)
// 未报错,提示: undefined
一个定义了但把值赋为undefined的 变量
demo3:
var p = 1
p = undefined
console.log(p)
// 未报错,提示: undefined
一个对象没有赋值的属性
demo4:
console.log(window.a)
// 未报错,提示: undefined
demo5:
var a = []
console.log(a.b)
// 未报错,提示: undefined
demo6:
var a = {}
console.log(a.b)
// 未报错,提示: undefined
一个没有返回值的函数
demo7:
function f() {console.log(1)}
console.log(f())
// 未报错,提示: undefined
有一点需要注意的是not defined 和 undefined 的typeof()的值都为”undefined”,所以无法用typeof()来判断这两者。
二.undefined 与 null
两者相同–在if语句里都被解析为false
demo8:
!undefined ? console.log('undefined is false') : console.log('undefined is not false')
// undefined is false
demo9:
!null? console.log('null is false') : console.log('null is not false')
// null is false
用法的不同
虽然null和undefined基本是同义的,但是在用法上还是有一些细微的差别的
null
null表示“没有对象”,即此处不该有值
1. 作为函数的参数,表示该函数的参数不是对象。
2. 作为对象原型链的终点。
demo10:
Object.getPrototypeof(object.prototype)
// null
undefined
如上文demo2-demo7 部分