在JS中undefined正确用法是什么,有哪些事项要注意
Admin 2022-08-11 群英技术资讯 888 次浏览
这篇文章将为大家详细讲解有关“在JS中undefined正确用法是什么,有哪些事项要注意”的知识,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
jQuery怎样实现控制按钮禁用的功能?控制按钮禁用的功能我们常在一些登录注册页面会使用到,例如发送登录验证码时,点击发送验证码之后,按钮被暂时禁用,5秒之后再取消禁用。下面我们就来看看这一需求怎样实现。
很多朋友比较喜欢玩一些网页小游戏,其实使用简单的JS代码也是可以实现有趣好玩的小游戏。这篇文章就给大家分享使用JS实现猜数字的游戏,实现代码及效果如下,感兴趣的朋友可以参考。
eclipse安装node.js的方法:1、在EclipseIDE界面上点击“help–>Eclipse Marketplace”;2、在Find输入“nodeclips”查询;3、选择“nodeclipse1.0.2”点击Install。
目录前言例子1. 模块加载2. jsonp动态加载script3. 执行异步脚本4. webpackJsonpCallback5. 执行异步模块代码流程图总结前言在vue中我们经常用到动态导入页面组件,那么它是如何实现的呢,本文将通过简单的案例,快速了解实现原理例子// index.jsimport(./test).t
在处理文本数据的时候,我们经常会需要把文本数据的行与列进行转换操作,这样更方便查看,本文就详细的介绍了vue3+el-table实现行列转换,感兴趣的可以了解一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008