成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

ES6 函數(shù)默認參數(shù)、TDZ以及Firefox 50.x 版本的實現(xiàn)

VioletJack / 905人閱讀

摘要:而我們使用額外的參數(shù)指向參數(shù)作用域中的時就可以執(zhí)行這里的的默認值會被賦予為而不是拋出異常,因為在從左向右初始化參數(shù)的時候已經(jīng)給賦予了。

ES6 函數(shù)默認參數(shù)、TDZ以及Firefox 50.x 版本的實現(xiàn) 從屬于 Web 前端入門與工程實踐

昨天看到阮老師發(fā)的一個微博:

筆者自己也嘗試了下,在 Chrome 中:

在 Firefox 與 Babel 中的效果:

理論上來說,ES6 中引入了 Temporal Dead Zone 的概念,即參數(shù)或者變量不可在初始化前被訪問,上述代碼中的= x賦值語句是在參數(shù)域中被執(zhí)行,因此會覆蓋掉全局定義中的x,自然就無法被初始化為自身。而我們使用額外的參數(shù)指向參數(shù)作用域中的x時就可以執(zhí)行:

function foo(x, y = x) { // OK
  ...
}

這里的y的默認值會被賦予為undefined而不是拋出異常,因為在從左向右初始化參數(shù)的時候已經(jīng)給x賦予了undefined。而在 Babel 中,因為其將默認參數(shù)解析為了具體的值判斷,因此不存在 TDZ 問題:

// ES6
function foo(x, y = function() { x = 2; }) {
  var x = 3;
  y(); // is `x` shared?
  console.log(x); // no, still 3, not 2
}
 
// Compiled to ES5
function foo(x, y) {
  // Setup defaults.
  if (typeof y == "undefined") {
    y = function() { x = 2; }; // now clearly see that it updates `x` from params
  }
 
  return function() {
    var x = 3; // now clearly see that this `x` is from inner scope
    y();
    console.log(x);
  }.apply(this, arguments);
}

不過號稱在 FF15 版本中就實現(xiàn)了默認參數(shù)的 Firefox 為何會與 Babel 有一樣的表現(xiàn)呢?筆者截止目前還沒有確定答案,有可能是 FF50 中還沒有實現(xiàn) TDZ 吧:

除此之外還有個小疑問:

function rest(b = a, ...a) {
console.log(b, a);
}

rest(undefined, 2);

上述代碼在 Chrome 中輸出為[2][2],F(xiàn)irefox 中輸出undefined,直接運行 Babel 拋出異常,官方 Babel 的編譯結(jié)果為:

"use strict";

function rest() {
  var b = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : a;

  for (var _len = arguments.length, a = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
    a[_key - 1] = arguments[_key];
  }

  console.log(b, a);
}

rest(undefined, 2);

執(zhí)行結(jié)果為undefined [2]

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81297.html

相關(guān)文章

  • 理解ES6暫時死區(qū)(TDZ)

    摘要:以英文名詞來說明,是時間的暫時的意義,則是死區(qū),意指電波達不到的區(qū)域。所以可以翻為時間上暫時的無法達到的區(qū)域,簡稱為時間死區(qū)或暫時死區(qū)。以聲明的變量或常量,必需是經(jīng)過對聲明的賦值語句的求值后,才算初始化完成,創(chuàng)建時并不算初始化。 Temporal Dead Zone(TDZ)是ES6(ES2015)中對作用域新的專用語義。TDZ名詞并沒有明確地寫在ES6的標準文件中,一開始是出現(xiàn)在ES...

    Mike617 評論0 收藏0
  • JS 中 TDZ 理解

    摘要:由于當時我本身也還不知道這一回事沒有看懂,所以就花了一些時間去搞清楚什么是及會帶來一些什么問題,本文主要是用于介紹我對的一些理解,如有問題,多謝指出。 原文鏈接:https://acrens.github.io/2017/01/22/2017-01-22-TDZ/春節(jié)快到了,假期也快到了,空閑之余刷個微博,看見 @ruanyf 提出了一個問題與 TDZ 有關(guān),但是貌似阮大當時還沒有意識...

    stackvoid 評論0 收藏0
  • ES6 系列之 let 和 const

    摘要:塊級作用域存在于函數(shù)內(nèi)部塊中字符和之間的區(qū)域和塊級聲明用于聲明在指定塊的作用域之外無法訪問的變量。和都是塊級聲明的一種。值得一提的是聲明不允許修改綁定,但允許修改值。這意味著當用聲明對象時沒有問題報錯臨時死區(qū)臨時死區(qū),簡寫為。 塊級作用域的出現(xiàn) 通過 var 聲明的變量存在變量提升的特性: if (condition) { var value = 1; } console.lo...

    PascalXie 評論0 收藏0
  • ES6簡記

    摘要:圓括號問題可以使用圓括號的情況只有一種賦值語句的非模式部分,可以使用圓括號。正確正確正確上面三行語句都可以正確執(zhí)行,因為首先它們都是賦值語句,而不是聲明語句其次它們的圓括號都不屬于模式的一部分。 let 和 const 命令 1.let 概念: 暫時性死區(qū)(TDZ) 在作用域內(nèi),let變量已經(jīng)存在;并綁定該作用域:不受外界影響,外界也不可獲取let作用域以代碼塊劃分,var作用域...

    renweihub 評論0 收藏0
  • ES6系列之 let 和 const

    摘要:聲明的變量不得改變值,這意味著,一旦聲明變量,就必須立即初始化,不能留到以后賦值。這在語法上,稱為暫時性死區(qū),簡稱。這表明函數(shù)內(nèi)部的變量與循環(huán)變量不在同一個作用域,有各自單獨的作用域。系列文章系列文章地址 showImg(https://segmentfault.com/img/bVbrjjC); 為什么需要塊級作用域 ES5 只有全局作用域和函數(shù)作用域,沒有塊級作用域,這帶來很多不合...

    libxd 評論0 收藏0

發(fā)表評論

0條評論

VioletJack

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<