JavaScript中直接写undefined的错误及用法剖析

 更新时间:2022年07月08日 14:23:10   作者:jsmask  
这篇文章主要介绍了JavaScript中直接写undefined的用法剖析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

介绍

众所周知,在JavaScript 语言中,一个没有被赋值的变量会有个默认值 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.undefinedwritablefalse 这意味着它是只读的没发写入修改,你在 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。

以上就是不要在JavaScript中直接写undefined了的详细内容,更多关于JavaScript undefined的资料请关注脚本之家其它相关文章!

相关文章

  • JavaScript 反射学习技巧

    JavaScript 反射学习技巧

    这篇文章主要给大家分享的是JavaScript 的反射学习技巧,主要是区别在于所有的函数对象属性过于复杂,而且额外增加可能会导致程序行为不合理,所以扩展 Reflect 函数来专门对函数对象处理调用方法,构造对象,获取或者设置属性等相关操作。下面一起进入文章内容吧
    2021-10-10
  • 5个实用的JavaScript新特性

    5个实用的JavaScript新特性

    这篇文章主要为大家介绍了5个实用的JavaScript新特性,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Express框架两个内置中间件方法详解

    Express框架两个内置中间件方法详解

    这篇文章主要为大家介绍了Express框架两个内置中间件方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • electron创建新窗口模态框并实现主进程传值给子进程

    electron创建新窗口模态框并实现主进程传值给子进程

    这篇文章主要为大家介绍了electron创建新窗口模态框并实现主进程传值给子进程示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 分享5个JS 高阶函数

    分享5个JS 高阶函数

    这篇文章主要给大家分享了5个JS高阶函数,在JavaScript中,函数实际上也是一个数据,也就是说函数也可以赋值给一个变量。本篇文章就来介绍一些JavaScript中的高阶函数的用法,具有一定的参考价值,需要的朋友可以参考一下
    2021-12-12
  • Proxy的不可变数据优点及使用详解

    Proxy的不可变数据优点及使用详解

    这篇文章主要为大家介绍了Proxy的不可变数据优点及使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • JavaScript立即执行函数用法解析

    JavaScript立即执行函数用法解析

    这篇文章主要介绍了JavaScript立即执行函数,我们知道,在一般情况下,函数必须先调用才能执行,如下所示,我们定义了一个函数,并且调用,下面一起进入文章来接具体的使用方法吧
    2021-12-12
  • js 交互在Flutter 中使用 webview_flutter

    js 交互在Flutter 中使用 webview_flutter

    这篇文章主要为大家介绍了js 交互在Flutter 中使用 webview_flutter示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 微信小程序 PHP后端form表单提交实例详解

    微信小程序 PHP后端form表单提交实例详解

    这篇文章主要介绍了微信小程序 PHP后端form表单提交实例详解的相关资料,需要的朋友可以参考下
    2017-01-01
  • Google 地图获取API Key详细教程

    Google 地图获取API Key详细教程

    本文主要介绍Google 地图API Key,开发Google 地图应用的朋友都知道,在开发的前需要免费的Google 地图API Key,这里详细给出获得API Key的流程,有需要的小伙伴参考下
    2016-08-08

最新评论