专栏首页偏前端工程师的驿站JS魔法堂:从void 0 === undefined说起

JS魔法堂:从void 0 === undefined说起

一、前言                                    

  当使用coffeescript书写如下代码时 name = person?.name 会被预编译为 var name = typeof person !== "undefined" && person !== null ? person.name : void 0; ,那么void 0到底是什么意思呢?运行得知void 0===undefined为true。那为什么不直接使用undefined而要使用void 0呢?而一元运算符void具体又有什么作用呢?下面将展开来说明。

二、为什么不直接用undefined                          

  undefined在JavaScript中并不属于保留字/关键字,因此在IE5.5~8中我们可以将其当作变量那样对其赋值(IE9+及其他现代浏览器中赋值给undefined将无效)

var undefinedBackup = undefined;
undefined = 1;
// 显示"undefined"
console.log(typeof undefinedBackup);  
// 在IE5.5~8中显示"number",其他浏览器中则显示"undefined"
console.log(typeof undefined);

  于是采用void方式获取undefined则成了通用准则。

三、一元运算符void的作用                         

  void在ECMAScript 262规范如下:

The void Operator The production UnaryExpression : void UnaryExpression is evaluated as follows:

Let expr be the result of evaluating UnaryExpression.

Call GetValue(expr).

Return undefined.

NOTE: GetValue must be called even though its value is not used because it may have observable side- effects.

   void的行为特点为:

  1. 不管void后的运算数是什么,只管返回纯正的undefined;

  2. void会对其后的运算数作取值操作,因此若属性有个getter函数,那么就会调用getter函数(因此会产生副作用)

var article = {
    _view: 0,
    get view(){
        console.log(this._view);
    return this._view++;
    }
};
var test = void article.view; // 显示0
console.log(test); // 显示undefined
console.log(article._view); // 显示1

   通过一元运算符 delete 作对比,delete的其中一个行为特点是不对其运算数进行取值操作(delete的其他行为特点比我们想的复杂得多,这里就不详细记录了)

var article = {
    _view: 0,
    get view(){
    console.log(this._view);
    return this._view++;
    }
};
var ret = delete article.view;
console.log(ret); // 显示true
console.log(article._view); // 显示0

四、还有啥方式可以得到纯正的undefined?                

  除了通过一元运算符void获取纯正的undefined,其实我们还有如下方法来获取:

  1. 未赋值的变量

var myUndefined;
console.log(typeof myUndefined); // 显示"undefined"

  2. 未赋值的实参(和未赋值的变量同理)

var getUndefined = function(undefined){
  return undefined;
};
var myUndefined = getUndefined();
// 或通过arguments获取
var getUndefined = function(){
  return arguments[arguments.length];
};

3. 无返回值函数

var getUndefined = function(){};
var myUndefined = getUndefined();

  4. 未定义的属性

var myUndefined1 = {}[''];
var myUndefined2 = [][0];

五、总结                              

  一个小小的void和undefined就这么好玩,前端的世界还有很多事情要深入研究哦!!

六、参考                              

谈谈Javascript中的void操作符

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • HTML5魔法堂:全面理解Drag & Drop API

    一、前言                                      在HTML4的时代,各前端工程师为了实现拖拽功能可说是煞费苦心,初听HTML...

    ^_^肥仔John
  • 前端魔法堂:屏蔽Backspace导致页面回退

    前言  前几天用户反映在录入资料时一不小心错按Backspace键,就会直接回退到是一个页面,导致之前辛辛苦苦录入的资料全部丢失了。哦?居然还有这种情况。下面我...

    ^_^肥仔John
  • .Net魔法堂:史上最全的ActiveX开发教程——ActiveX与JS间交互篇

    一、前言                             经过上几篇的学习,现在我们已经掌握了ActiveX的整个开发过程,但要发挥ActiveX的真正...

    ^_^肥仔John
  • JS-面向对象

    xing.org1^
  • Python格式化输出总结

    py3study
  • 列表、存储以及WebView 相关优化

    不要在你的getView()中写过多的逻辑代码,我们能够将这些代码放在别的地方。比如:

    Yif
  • 手把手教你画不一样的韦恩图

    看到这两张图是不是突然觉得有一种我文章正好需要这个图的感觉,我们接下来将每周分享一图。一提到韦恩图大家感觉都可以画,但是好看的美观的韦恩图却不是那么多,今天我们...

    百味科研芝士
  • 【MATLAB 从零到进阶】day11 描述性统计

    均值mean 方差var和标准差std 最值max/min 极差range 中位数median 分位数quantile/prctile 众数mode...

    统计学家
  • 06-性能测试之JMeter参数化

    参数化是自动化测试脚本的一种常用技巧。简单来说,参数化的一般用法就是将脚本中的某些输入使用参数来代替,在脚本运行时指定参数的取值范围和规则,这样,脚本在运行的时...

    测试邦
  • R大有时会颠覆你对Java的认知

    关于volatile变量的内存可见性,我在JVM群中抛出了一个问题,然后我的一些认知就被颠覆了。

    程序员小强

扫码关注云+社区

领取腾讯云代金券