前言:
很多人写JavaScript代码时习惯用var a = undefined 这种写法,其实这种写在某种情况下会产生意想不到的bug,又或者说undefined本身就是JavaScript的一个bug?? 为什么这么说呢, 因为undefined它应该是关健字才合理的,但undefined在JavaScript里面压根就不是关健字,它是window的一个属性即window.undefined, 没想到吧。
为什么发现这个冷门知识点??
因为最近在拜读一些包的底层源码时,发现有一种很有意思的写法我不太理解var a = void 0; 然后我就去各方查资料,发现这种写法有两个好处,1、是能降低文件大小,2、秉承犀牛书的观点,任何时候都不主动声明undefined。
任何时候都不主动声明undefined的原因
前面说到了undefined在JavaScript里面压根就不是关健字,而是一个属性,在控制台window.undefined就知道了
但它是一个只读属性,我们是无法对undefined重新赋值的
虽然是只读属性,但是在特定条件下还是会出现bug,如下所示
javascript
function test() {
var undefined = '我是test';
var a = undefined;
console.log(a)
}
test() // '我是test'
看出来问题了不,var a = undefined 但 这里的undefined是方法内部的undefined而不是window的,所以拿到的是'我是test', 虽然理论上不会出现这种场景,但这确实就是一个漏洞了。
推荐写法
犀牛书的观点,用null表示空,但用 var a = void 0 这种写法也行。void后面不一定就是写0,因为void 表达式最终会返回一个undefined,如下所示。
注意:void是会执行右边的语句然后返回undefined。所以如果右边语句有副作用的话还是能看到不一样的,所以用一个无副作用的0
总结:
一个很有意思的小知识点,单纯是分享一下互相学习。