文章出處

一、前言                                    

  當使用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就這么好玩,前端的世界還有很多事情要深入研究哦!!

  尊重原創,轉載請注明來自:http://www.cnblogs.com/fsjohnhuang/p/4146506.html^_^肥子John

 

六、參考                              

談談Javascript中的void操作符


文章列表




Avast logo

Avast 防毒軟體已檢查此封電子郵件的病毒。
www.avast.com


arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()