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

資訊專欄INFORMATION COLUMN

Runtime transform/runtime 轉(zhuǎn)化器詳解

FrancisSoung / 614人閱讀

摘要:并且作為生產(chǎn)版本依賴設(shè)置轉(zhuǎn)換器插件一般只用在開發(fā)時(shí),而里面的實(shí)際墊片的代碼在你部署或發(fā)布庫(kù)時(shí)是需要放到其中的。轉(zhuǎn)換器所做的是轉(zhuǎn)換成如下添加到這意味著你可以無(wú)縫的使用本地內(nèi)置的方法而不用考慮是來(lái)自墊片還是本地。。

Runtime transform 運(yùn)行時(shí)編譯es6

入口文件引用作為輔助和內(nèi)建,自動(dòng)添加墊片到你的當(dāng)前代碼模塊而非全局

這個(gè)插件建議放在 library/tool中

注意:
實(shí)例方法,例如"foobar".includes("foo")將不能夠使用,因?yàn)樗鼘⑿拚齼?nèi)置的墊片。

為什么使用它 why

Babel對(duì)常用的函數(shù)使用非常小的輔助(內(nèi)置的墊片比較少),例如_extend。默認(rèn)情況下它將會(huì)添加到每個(gè)引用的文件。這種重復(fù)有時(shí)候是非常沒必要的。特別是你的應(yīng)用分散在很多文件中。

這是transform-runtime插件之所以產(chǎn)生的原因:所有的這些輔助(墊片)將會(huì)引用babel-runtime來(lái)避免編譯時(shí)重復(fù)。runtime將會(huì)編譯到你的build中。

另一個(gè)目的是,這個(gè)轉(zhuǎn)換器為你的代碼創(chuàng)建了一個(gè)沙盒環(huán)境。如果你使用babel-polyfill并且把它內(nèi)置提供promise,set,map這樣的對(duì)象或功能,他們將會(huì)污染全局環(huán)境。也許在一個(gè)應(yīng)用中或者命令行工具中沒問題,但是如果你的代碼是個(gè)庫(kù),你想發(fā)布給其他人使用,因?yàn)槭褂玫娜丝赡茉诟鞣N各樣的執(zhí)行環(huán)境中,所以可能導(dǎo)致錯(cuò)誤,不能執(zhí)行。

轉(zhuǎn)換器transformer會(huì)將這些內(nèi)置(墊片)設(shè)置別名到core-js中,因此你可以不使用require來(lái)無(wú)縫的使用(墊片中的對(duì)象和方法)。

如何生效和工作,請(qǐng)看技術(shù)細(xì)節(jié)

安裝

注意:生產(chǎn)版本(Production) vs 開發(fā)版本(development)依賴

在大多數(shù)情況下,你需要安裝babel-plugin-transform-runtime作為開發(fā)版本的依賴(設(shè)置--save-dev)。

npm install --save-dev babel-plugin-transform-runtime

并且babel-runtime作為生產(chǎn)版本依賴(設(shè)置 --save)

npm install --save babel-runtime

轉(zhuǎn)換器插件一般只用在開發(fā)時(shí),而里面的實(shí)際墊片(runtime itself)的代碼在你部署或發(fā)布庫(kù)時(shí)是需要放到其中的。

請(qǐng)看下面的例子

用法 通過(guò).babelrc(推薦)

把下面的代碼添加到你的babelrc文件中(這里說(shuō)的是兩種情況):

默認(rèn)設(shè)置選項(xiàng)時(shí)的寫法

{
  "plugins": ["transform-runtime"]
}

使用自己設(shè)置設(shè)置

{
  "plugins": [
    ["transform-runtime", {
      "helpers": false,
      "polyfill": false,
      "regenerator": true,
      "moduleName": "babel-runtime"
    }]
  ]
}
通過(guò)命令行(CLI)
babel --plugins transform-runtime script.js
通過(guò)Node 接口 (Node API)
require("babel-core").transform("code",{
    plugins:["transform-runtime"]
})
選項(xiàng)/設(shè)置 輔助(helpers)

默認(rèn)值是:true

表示是否開啟內(nèi)聯(lián)的babel helpers(即babel或者環(huán)境本來(lái)的存在的墊片或者某些對(duì)象方法函數(shù))(clasCallCheck,extends,etc)在調(diào)用模塊名字(moduleName)時(shí)將被替換名字。

查看詳情

墊片/polyfill

默認(rèn)值是:`true"

表示是否把內(nèi)置的東西(Promise,Set,Map,tec)轉(zhuǎn)換成非全局污染墊片。
查看詳情

重新生成/regenerator

默認(rèn)值是:true

是否開啟generator函數(shù)轉(zhuǎn)換成使用regenerator runtime來(lái)避免污染全局域。

查看詳情

模塊名字/moduleName

默認(rèn)值:babel-runtime

當(dāng)調(diào)用輔助(內(nèi)置墊片)設(shè)置模塊(module)名字/路徑.

例子:
json

{
  "moduleName": "flavortown/runtime"
}

javascript

import extends from "flavortown/runtime/helpers/extends";
技術(shù)細(xì)節(jié)/Techincal details

runtime轉(zhuǎn)換器插件主要做了三件事:

當(dāng)你使用generators/async方法、函數(shù)時(shí)自動(dòng)調(diào)用babel-runtime/regenerator

當(dāng)你使用ES6 的Map或者內(nèi)置的東西時(shí)自動(dòng)調(diào)用babel-runtime/core-js

移除內(nèi)聯(lián)babel helpers并替換使用babel-runtime/helpers來(lái)替換

總的來(lái)說(shuō)一句話,你可以使用內(nèi)置的一些東西例如Promise,Set,Symbol等,就像使用無(wú)縫的使用polyfill,來(lái)使用babel 特性,并且無(wú)全局污染、極高代碼庫(kù)適用性。

再生器別名 Regenerator aliasing

無(wú)論你什么時(shí)候使用generator函數(shù)或者異步函數(shù)(async function).

function* foo(){

}

下面的將被生成:

"use strict";

var _marked = [foo].map(regeneratorRuntime.mark);

function foo() {
  return regeneratorRuntime.wrap(function foo$(_context) {
    while (1) switch (_context.prev = _context.next) {
      case 0:
      case "end":
        return _context.stop();
    }
  }, _marked[0], this);
}

這種是不太理想的。因?yàn)槟鉹egenerator運(yùn)行時(shí)會(huì)污染全局域的。
作為替代你需要runtime轉(zhuǎn)換器來(lái)編譯成:

"use strict";

var _regenerator = require("babel-runtime/regenerator");

var _regenerator2 = _interopRequireDefault(_regenerator);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

var _marked = [foo].map(_regenerator2.default.mark);

function foo() {
  return regeneratorRuntime.wrap(function foo$(_context) {
    while (1) switch (_context.prev = _context.next) {
      case 0:
      case "end":
        return _context.stop();
    }
  }, _marked[0], this);
}

這意味著在使用regenerator時(shí)不會(huì)污染當(dāng)前的全局環(huán)境。

core-js的別名化/core-js aliasing

有時(shí)你想去使用內(nèi)置的的東西(Promise,Set,Map,etc)。通常情況下你會(huì)使用一個(gè)全局的墊片。
runtime轉(zhuǎn)換器所做的是轉(zhuǎn)換成如下:

var sym = Symbol();

var promise = new Promise;

console.log(arr[Symbol.iterator]());

添加到

"use strict";

var _getIterator2 = require("babel-runtime/core-js/get-iterator");

var _getIterator3 = _interopRequireDefault(_getIterator2);

var _promise = require("babel-runtime/core-js/promise");

var _promise2 = _interopRequireDefault(_promise);

var _symbol = require("babel-runtime/core-js/symbol");

var _symbol2 = _interopRequireDefault(_symbol);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

var sym = (0, _symbol2.default)();

var promise = new _promise2.default();

console.log((0, _getIterator3.default)(arr));

這意味著你可以無(wú)縫的使用本地內(nèi)置的方法而不用考慮是來(lái)自墊片還是本地。。
警告,實(shí)例方法將不能使用,例如"foobar".includes("foo")

輔助重命名 / Helper aliasing

通常babel會(huì)把輔助放在文件的頂部做一些常用任務(wù)來(lái)避免重復(fù)導(dǎo)入。
有時(shí)這些輔助的體積有點(diǎn)大并且不需要的沒有用的東西也在其中。runtime轉(zhuǎn)換器把所有的輔助轉(zhuǎn)換到一個(gè)模塊中(按他的意思是說(shuō)只是把用到的轉(zhuǎn)換到其中)。

如下演示:

class Person {
}

一般的轉(zhuǎn)化成(即不是用runtime):

"use strict";

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

var Person = function Person() {
  _classCallCheck(this, Person);
};

runtime轉(zhuǎn)化器轉(zhuǎn)化成:

"use strict";

var _classCallCheck2 = require("babel-runtime/helpers/classCallCheck");

var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

var Person = function Person() {
  (0, _classCallCheck3.default)(this, Person);
};

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

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

相關(guān)文章

  • babel入門

    摘要:為了方便,團(tuán)隊(duì)將一些集合在一起,并稱之為。先看一下直觀體驗(yàn)源代碼配置編譯后的代碼通過(guò)對(duì)比可以看出,第二種方案直接從引入,避免自己定義,從而減少代碼的體積。 Babel Babel 是一個(gè) JavaScript 編譯器,它可以將ES6+語(yǔ)法編譯為瀏覽器支持的ES5語(yǔ)法。要學(xué)好babel必須先理解相關(guān)的概念,但是你剛起步就去扣這些細(xì)節(jié)的話,很可能因?yàn)閎abel一些復(fù)雜而模糊的概念打擊你的信...

    pkwenda 評(píng)論0 收藏0
  • webpack的Babel加載器

    摘要:的轉(zhuǎn)譯過(guò)程分為三個(gè)階段。標(biāo)準(zhǔn)為例,提供了如下的一些的只轉(zhuǎn)譯該年份批準(zhǔn)的標(biāo)準(zhǔn),而則代指最新的標(biāo)準(zhǔn),包括和。未完待續(xù),繼續(xù)學(xué)習(xí)繼續(xù)補(bǔ)充哦參考文獻(xiàn)深入理解原理及其使用 Babel Babel的轉(zhuǎn)譯過(guò)程分為三個(gè)階段: parsing, transforming, generating。babel只是轉(zhuǎn)譯新標(biāo)準(zhǔn)引入的語(yǔ)法,比如ES6的箭頭函數(shù)轉(zhuǎn)譯成ES5的函數(shù);而新標(biāo)準(zhǔn)引入的原生對(duì)象,部分原生對(duì)...

    Ali_ 評(píng)論0 收藏0
  • webpack實(shí)戰(zhàn)

    摘要:和類似的預(yù)處理器還有等。的用處非常多,包括給自動(dòng)加前綴使用下一代語(yǔ)法等,目前越來(lái)越多的人開始用它,它很可能會(huì)成為預(yù)處理器的最終贏家。 webpack實(shí)戰(zhàn) 查看所有文檔頁(yè)面:全棧開發(fā),獲取更多信息。快馬加鞭,加班加點(diǎn),終于把這個(gè)文檔整理出來(lái)了,順便深入地學(xué)習(xí)一番,鞏固知識(shí),就是太累人,影響睡眠時(shí)間和質(zhì)量。極客就是想要把事情做到極致,開始了就必須到達(dá)終點(diǎn)。 原文鏈接:webpack實(shí)戰(zhàn),原...

    cyrils 評(píng)論0 收藏0
  • Web前端開發(fā)過(guò)程踩過(guò)的坑以及一些小方法技巧(持續(xù)更新)

    摘要:一上瀏覽器使用不允許事件代理到上選擇器以上綁定可能會(huì)出現(xiàn)點(diǎn)擊失效的情況。對(duì)于,如果工具是以下版本,在中加入以下代碼以上的版本加入以下代碼八開發(fā)對(duì)于文件的處理問題。解決方法有給元素設(shè)置絕對(duì)定位即可。元素?fù)Q成內(nèi)聯(lián)元素,如。 一、iOS上瀏覽器使用jQuery不允許事件代理到document上 $(document).on(click, 選擇器, function(){}); 以上綁定可能...

    arashicage 評(píng)論0 收藏0
  • Web前端開發(fā)過(guò)程踩過(guò)的坑以及一些小方法技巧(持續(xù)更新)

    摘要:一上瀏覽器使用不允許事件代理到上選擇器以上綁定可能會(huì)出現(xiàn)點(diǎn)擊失效的情況。對(duì)于,如果工具是以下版本,在中加入以下代碼以上的版本加入以下代碼八開發(fā)對(duì)于文件的處理問題。解決方法有給元素設(shè)置絕對(duì)定位即可。元素?fù)Q成內(nèi)聯(lián)元素,如。 一、iOS上瀏覽器使用jQuery不允許事件代理到document上 $(document).on(click, 選擇器, function(){}); 以上綁定可能...

    binta 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

FrancisSoung

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<