JavaScript不建议直接声明undefined的原因,极致的严谨和仔细

前言:

很多人写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

总结:

一个很有意思的小知识点,单纯是分享一下互相学习。

相关推荐
excel3 小时前
为什么在 Three.js 中平面能产生“起伏效果”?
前端
excel4 小时前
Node.js 断言与测试框架示例对比
前端
天蓝色的鱼鱼5 小时前
前端开发者的组件设计之痛:为什么我的组件总是难以维护?
前端·react.js
codingandsleeping5 小时前
使用orval自动拉取swagger文档并生成ts接口
前端·javascript
石金龙6 小时前
[译] Composition in CSS
前端·css
白水清风6 小时前
微前端学习记录(qiankun、wujie、micro-app)
前端·javascript·前端工程化
Ticnix7 小时前
函数封装实现Echarts多表渲染/叠加渲染
前端·echarts
用户22152044278007 小时前
new、原型和原型链浅析
前端·javascript
阿星做前端7 小时前
coze源码解读: space develop 页面
前端·javascript
叫我小窝吧7 小时前
Promise 的使用
前端·javascript