博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS魔法堂:从void 0 === undefined说起
阅读量:7222 次
发布时间:2019-06-29

本文共 2163 字,大约阅读时间需要 7 分钟。

一、前言                                    

  当使用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; // 显示0console.log(test); // 显示undefinedconsole.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); // 显示trueconsole.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就这么好玩,前端的世界还有很多事情要深入研究哦!!

转载地址:http://qieym.baihongyu.com/

你可能感兴趣的文章
解决数据库 Table 'content_tags' is marked as crashed and should be repaired 表损坏问题
查看>>
算法-随手写的二分查找
查看>>
测量史上首个易语言工程测量模块
查看>>
面向对象初步总结
查看>>
分享45个设计师应该见到的新鲜的Web移动设备用户界面PSD套件
查看>>
SDL_BlitSurface
查看>>
Ubuntu12.04编译Android2.3.4
查看>>
IDA设置函数类型
查看>>
日期控件ie9失效
查看>>
群里一个高手写的url?传参执行php函数的小程序, 收藏下
查看>>
Linux桌面扩展 Docky
查看>>
Android实现图片顺时逆时旋转及拖拽显示效果
查看>>
四款常见数据库比较同步软件汇总
查看>>
java中相同名字不同返回类型的方法
查看>>
北京出dell s2740显示器 1900 - V2EX
查看>>
怎么在VS监视DataSet类型的数据
查看>>
一个Chrome拓展——HttpPost
查看>>
JS事件监听器
查看>>
解决flash web浏览器弹出窗口被拦截的问题
查看>>
easyui资源
查看>>