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

总结:

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

相关推荐
一 乐20 分钟前
家政服务管理系统|基于springboot + vue家政服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·家政服务管理系统
IT_陈寒23 分钟前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
烬羽1 小时前
后端返回的 JSON 字符串,浏览器怎么"看懂"的?——Ajax 全链路拆解
javascript
tedcloud1231 小时前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge
xinhuanjieyi1 小时前
html修复游戏种太阳错误
前端·游戏·html
半个落月2 小时前
一个新手用 Bun + Axios 调通 DeepSeek API 的实践记录
javascript
不好听6132 小时前
深入理解链表:线性数据结构的另一面
javascript·数据结构
林希_Rachel_傻希希2 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
小林ixn2 小时前
从 Ajax 到异步编程:JSON 序列化、Event Loop 与 XHR 请求完全解析
javascript
Cache技术分享2 小时前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端