在JS中undefined正确用法是什么,有哪些事项要注意
Admin 2022-08-11 群英技术资讯 487 次浏览
undefined
,而 undefined
作为全局对象的一个属性经常会用作一些赋值返回,逻辑判断等业务场景中。可本期要说的是,尽量不要直接去拼写 undefined
了,因为那是不太严谨的行为,可能出现很多意外情况。我们经常在判断某个变量是否等于 undefined
,如下:
function test(value) { if (value === undefined) { return `value is undefined`; } return `value is not undefined`; } let value; test(value); // 'value is undefined'
这样看上去没有什么毛病,而且 window.undefined
的 writable
为 false
这意味着它是只读的没发写入修改,你在 window
下,修改 undefined
也是无济于事。
undefined = "hello world"; console.log(undefined); // undefined
对这样是没错,看似万无一失。但是还有一种情况没有考虑到,那就是 undefined
它是 window
对象的一个全局属性,那么我们可以局部也起一个也叫 undefined
的变量给它赋值,那么问题就来了。如下:
function test(value) { let undefined = "hello world"; if (value === undefined) { return `value is undefined`; } return `value is not undefined`; } let value; test(value); // 'value is not undefined'
我们可以看到验证入参是否是 undefined
的方法就出现了bug。因为,我们把 undefined
赋了一个新值,在这个作用域下找到的所有 undefined
都是那个新的值,这样我们就没法通过这种方式去验证判断 undefined
了。
不卖关子了,我们通常会用 void 0
或者 void(0)
来去直接替代 undefined
,因为他返回的也是 undefined
。
function test(value) { let undefined = "hello world"; if (value === void 0) { return `value is undefined`; } return `value is not undefined`; } let value; test(value); // 'value is undefined'
void
运算符是对给定的表达式进行求值,然后返回 undefined
。而且, void
是不能重新定义的,不然会报语法错误,这样也保证了用 void
来代替 undefined
的不会出现被重定义而造成的bug。
function func() { var void = function() {}; return void(0); } // Uncaught SyntaxError: Unexpected token 'void'
其实在很早之前,很多大厂的前端规范都会写到用 void 0
去代替 undefined
作为准则,去防止一些意外发生。对于大型项目来说,这点严谨也是值得考虑的。 PS:随着前端工程化的推进,打包和校验时都会规避掉这个问题,但我们依然要认识到这个写法背后的原因,养成习惯,虽然后面遇到的可能性概率几乎为0。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
React 主要用于构建UI,很多人认为 React 是 MVC 中的 V(视图)。本文给大家介绍React 非父子组件传参的相关知识,感兴趣的朋友跟随一起看看吧
Javascript的异步函数和Promise对象的相关知识,有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
这篇我们来了解Node.js中puppeteer库如何安装和使用,以及能用做什么?文中的介绍很详细,有具体示例供大家参考,对大家学习和了解puppeteer库的使用有帮助,感兴趣的朋友就继续往下看吧。
vue渲染不上数据的问题如何解决?这里提到的vue渲染不上数据的问题是能获取到数据,但是数据却渲染不到页面上。那么什么方法可以解决这个问题呢?下面我们一起来探讨一下。
本文实例为大家分享了vue实现列表垂直无缝滚动的具体代码,供大家参考,具体内容如下实现新闻列表的轮播(如下图)上代码封装的so-marquee.vuetemplate div class=marquee-wrapper :style={ width: realWidth + px }
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008