JS魔法堂:从void 0 === undefined提及

1、前言                                    html

  当使用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具体又有什么做用呢?下面将展开来讲明。前端

 

2、为何不直接用undefined                          segmentfault

  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则成了通用准则。ide

 

3、一元运算符void的做用                         函数

  void在ECMAScript 262规范以下:this

The void Operatorlua

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

  • 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.code

   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

 

4、还有啥方式能够获得纯正的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];

 

5、总结                              

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

  尊重原创,转载请注明来自:http://www.cnblogs.com/fsjohnhuang/p/4146506.html^_^肥子John

 

6、参考                              

谈谈Javascript中的void操做符

相关文章
相关标签/搜索