国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

webpack2 示例之:Scope Hoisting 和 Code Splitting

chunquedong / 718人閱讀

摘要:原文鏈接譯者這個(gè)示例演示了與代碼拆分相結(jié)合的。這是示例的依賴(lài)圖實(shí)線表示同步導(dǎo)入,虛線表示異步導(dǎo)入除之外的所有模塊都是模塊。為了避免沖突,模塊中的模塊連接標(biāo)識(shí)符被重命名,并簡(jiǎn)化了內(nèi)部導(dǎo)入。根模塊的外部導(dǎo)入和導(dǎo)出使用現(xiàn)有的結(jié)構(gòu)。

原文鏈接:https://github.com/webpack/we...
譯者:@justjavac

這個(gè)示例演示了與代碼拆分相結(jié)合的 Scope Hoisting。

這是示例的依賴(lài)圖:(實(shí)線表示同步導(dǎo)入,虛線表示異步導(dǎo)入)

cjs 之外的所有模塊都是 EcmaScript 模塊。cjs 是 CommonJs 模塊。

有趣的是,將所有模塊放在單一范圍(scope)內(nèi)將無(wú)法正常工作,原因如下:

模塊 lazy, c, dcjs 需要在一個(gè)多帶帶的塊(chunk)

模塊 shared 可以被兩個(gè) chunk 訪問(wèn)(不同的范圍)

模塊 cjs 是一個(gè) CommonJs 模塊

因此,Webpack 使用一種稱(chēng)為“局部范圍提升(Partial Scope Hoisting)”或“模塊級(jí)聯(lián)”的方法,該方法選擇可以可以覆蓋 Scope Hoisting 范圍的 ES 模塊的最大子集,并將其與默認(rèn)的 webpack 原語(yǔ)(primitives)相結(jié)合。

為了避免沖突,模塊中的模塊連接標(biāo)識(shí)符被重命名,并簡(jiǎn)化了內(nèi)部導(dǎo)入。根模塊的外部導(dǎo)入和導(dǎo)出使用現(xiàn)有的 ESM 結(jié)構(gòu)。

example.js
import { a, x, y } from "a";
import * as b from "b";

import("./lazy").then(function(lazy) {
    console.log(a, b.a(), x, y, lazy.c, lazy.d.a, lazy.x, lazy.y);
});
lazy.js
export * from "c";
import * as d from "d";
export { d };
a.js
// module a
export var a = "a";
export * from "shared";
b.js
// module b
export function a() {
    return "b";
};
c.js
// module c
import { c as e } from "cjs";

export var c = String.fromCharCode(e.charCodeAt(0) - 2);

export { x, y } from "shared";
d.js
// module d
export var a = "d";
cjs.js
// module cjs (commonjs)
exports.c = "e";
shared.js
// shared module
export var x = "x";
export * from "shared2";
shared2.js
// shared2 module
export var y = "y";
webpack.config.js
var webpack = require("../../");

module.exports = {
    plugins: [
        new webpack.optimize.ModuleConcatenationPlugin()
    ]
};
js/output.js
/******/ (function(modules) { /* webpackBootstrap */ })
......
/******/ ([
/* 0 */
/*!********************************************!*
  !*** ./node_modules/shared.js + 1 modules ***!
  ********************************************/
/*! exports provided: x, y */
/*! exports used: x, y */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });

// CONCATENATED MODULE: ./node_modules/shared2.js
// shared2 module
var y = "y";

// CONCATENATED MODULE: ./node_modules/shared.js
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return x; });
/* concated harmony reexport */__webpack_require__.d(__webpack_exports__, "b", function() { return y; });
// shared module
var x = "x";



/***/ }),
/* 1 */
/*!********************************!*
  !*** ./example.js + 2 modules ***!
  ********************************/
/*! exports provided:  */
/*! all exports used */
/*! ModuleConcatenation bailout: Module is an entry point */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });

// EXTERNAL MODULE: ./node_modules/shared.js + 1 modules
var shared = __webpack_require__(0);

// CONCATENATED MODULE: ./node_modules/a.js
// module a
var a = "a";


// CONCATENATED MODULE: ./node_modules/b.js
// module b
function b_a() {
    return "b";
};

// CONCATENATED MODULE: ./example.js



__webpack_require__.e/* import() */(0).then(__webpack_require__.bind(null, /*! ./lazy */ 3)).then(function(lazy) {
    console.log(a, b_a(), shared["a" /* x */], shared["b" /* y */], lazy.c, lazy.d.a, lazy.x, lazy.y);
});


/***/ })
/******/ ]);
js/0.output.js
webpackJsonp([0],[
/* 0 */,
/* 1 */,
/* 2 */
/*!*****************************!*
  !*** ./node_modules/cjs.js ***!
  *****************************/
/*! no static exports found */
/*! exports used: c */
/*! ModuleConcatenation bailout: Module is not an ECMAScript module */
/***/ (function(module, exports) {

// module cjs (commonjs)
exports.c = "e";


/***/ }),
/* 3 */
/*!*****************************!*
  !*** ./lazy.js + 2 modules ***!
  *****************************/
/*! exports provided: d, c, x, y */
/*! all exports used */
/*! ModuleConcatenation bailout: Module is referenced from these modules with unsupported syntax: ./example.js (referenced with import()) */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
var d_namespaceObject = {};
__webpack_require__.d(d_namespaceObject, "a", function() { return a; });

// EXTERNAL MODULE: ./node_modules/cjs.js
var cjs = __webpack_require__(2);
var cjs_default = /*#__PURE__*/__webpack_require__.n(cjs);

// EXTERNAL MODULE: ./node_modules/shared.js + 1 modules
var shared = __webpack_require__(0);

// CONCATENATED MODULE: ./node_modules/c.js
// module c


var c = String.fromCharCode(cjs["c"].charCodeAt(0) - 2);



// CONCATENATED MODULE: ./node_modules/d.js
// module d
var a = "d";

// CONCATENATED MODULE: ./lazy.js
/* concated harmony reexport */__webpack_require__.d(__webpack_exports__, "c", function() { return c; });
/* concated harmony reexport */__webpack_require__.d(__webpack_exports__, "x", function() { return shared["a" /* x */]; });
/* concated harmony reexport */__webpack_require__.d(__webpack_exports__, "y", function() { return shared["b" /* y */]; });
/* concated harmony reexport */__webpack_require__.d(__webpack_exports__, "d", function() { return d_namespaceObject; });





/***/ })
]);

Minimized

webpackJsonp([0],[,,function(n,r){r.c="e"},function(n,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var e={};t.d(e,"a",function(){return d});var u=t(2),c=t(0),o=String.fromCharCode(u.c.charCodeAt(0)-2),d="d";t.d(r,"c",function(){return o}),t.d(r,"x",function(){return c.a}),t.d(r,"y",function(){return c.b}),t.d(r,"d",function(){return e})}]);
Info Uncompressed
Hash: 6596ce0a50ccbbaa89c6
Version: webpack 3.5.1
      Asset     Size  Chunks             Chunk Names
0.output.js   1.9 kB       0  [emitted]  
  output.js  7.39 kB       1  [emitted]  main
Entrypoint main = output.js
chunk    {0} 0.output.js 286 bytes {1} [rendered]
    > [] 4:0-16
    [3] ./lazy.js + 2 modules 242 bytes {0} [built]
        [exports: d, c, x, y]
        import() ./lazy [] ./example.js 4:0-16
     + 1 hidden module
chunk    {1} output.js (main) 390 bytes [entry] [rendered]
    > main [] 
    [0] ./node_modules/shared.js + 1 modules 105 bytes {1} [built]
        [exports: x, y]
        [only some exports used: x, y]
        harmony import shared [1] ./example.js + 2 modules 3:0-23
        harmony import shared [3] ./lazy.js + 2 modules 6:0-30
    [1] ./example.js + 2 modules 285 bytes {1} [built]
        [no exports]
Minimized (uglify-js, no zip)
Hash: 6596ce0a50ccbbaa89c6
Version: webpack 3.5.1
      Asset       Size  Chunks             Chunk Names
0.output.js  364 bytes       0  [emitted]  
  output.js    1.66 kB       1  [emitted]  main
Entrypoint main = output.js
chunk    {0} 0.output.js 286 bytes {1} [rendered]
    > [] 4:0-16
    [3] ./lazy.js + 2 modules 242 bytes {0} [built]
        [exports: d, c, x, y]
        import() ./lazy [] ./example.js 4:0-16
     + 1 hidden module
chunk    {1} output.js (main) 390 bytes [entry] [rendered]
    > main [] 
    [0] ./node_modules/shared.js + 1 modules 105 bytes {1} [built]
        [exports: x, y]
        [only some exports used: x, y]
        harmony import shared [1] ./example.js + 2 modules 3:0-23
        harmony import shared [3] ./lazy.js + 2 modules 6:0-30
    [1] ./example.js + 2 modules 285 bytes {1} [built]
        [no exports]

歡迎關(guān)注我的公眾號(hào),關(guān)注前端文章:

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/84796.html

相關(guān)文章

  • 2017-08-22 前端日?qǐng)?bào)

    摘要:前端日?qǐng)?bào)精選專(zhuān)題之惰性函數(shù)中的執(zhí)行上下文和調(diào)用棧是什么個(gè)人總結(jié)新特性緩存機(jī)制詳解技術(shù)內(nèi)幕的秘密中文第期給前端工程師講設(shè)計(jì)終篇行代碼搭建神經(jīng)網(wǎng)絡(luò)知乎專(zhuān)欄版模塊,桌面支付請(qǐng)求,,以及眾成翻譯你應(yīng)該知道的知乎專(zhuān)欄技術(shù)周刊同步代碼書(shū)寫(xiě)異 2017-08-22 前端日?qǐng)?bào) 精選 JavaScript專(zhuān)題之惰性函數(shù)JavaScript 中的執(zhí)行上下文和調(diào)用棧是什么?個(gè)人總結(jié)(css3新特性) HTT...

    Fundebug 評(píng)論0 收藏0
  • webpack2.x 中文文檔 翻譯 分離庫(kù)代碼Code Splitting - Librari

    摘要:瀏覽器需要重新下載打包后的文件,即使文件的絕大部分都沒(méi)有變化。分離并且以來(lái)命名新的入口能夠緩和當(dāng)前的問(wèn)題。現(xiàn)在運(yùn)行綁定的檢查結(jié)果是只是被綁定到這個(gè)綁定文件中。 分離庫(kù)代碼Code Splitting - Libraries 這個(gè)在webpack2.x中文網(wǎng)已存在,點(diǎn)擊這里 讓我們想一個(gè)簡(jiǎn)單的應(yīng)用——momentjs,他是一個(gè)事件格式化的庫(kù)。安裝moment. npm install -...

    elva 評(píng)論0 收藏0
  • webpack2.x 代碼分離文檔 翻譯

    摘要:代碼分離代碼分離是最受矚目的功能。下面有兩種代碼分離的技術(shù)。使用實(shí)現(xiàn)代碼分離是使用的方式實(shí)現(xiàn)靜待資源異步調(diào)用。通過(guò)添加,我們可以在代碼中打一個(gè)分離點(diǎn),可以以此建立一個(gè)獨(dú)立的包,包含這個(gè)點(diǎn)的所有代碼。 代碼分離(Code Splitting) 代碼分離是webpack最受矚目的功能。它允許你把你的代碼分成不同的部分分開(kāi)打包,然后實(shí)現(xiàn)在需要的時(shí)候再進(jìn)行加載(按需加載提高速度)————例如用...

    Scott 評(píng)論0 收藏0
  • 2017-06-28 前端日?qǐng)?bào)

    摘要:前端日?qǐng)?bào)精選我是如何實(shí)現(xiàn)的在線升級(jí)熱更新功能的張?chǎng)涡聆慰臻g鑫生活翻譯表單的運(yùn)用第期晉升評(píng)審的套路異步編程的四種方式黃博客精選組件設(shè)計(jì)和分解思考掘金中文譯使登錄頁(yè)面變得正確掘金前端從強(qiáng)制開(kāi)啟壓縮探究插件運(yùn)行機(jī)制掘金個(gè)常用的簡(jiǎn) 2017-06-28 前端日?qǐng)?bào) 精選 我是如何實(shí)現(xiàn)electron的在線升級(jí)熱更新功能的? ? 張?chǎng)涡?鑫空間-鑫生活【翻譯】React 表單: Refs 的運(yùn)用【...

    QLQ 評(píng)論0 收藏0
  • [翻譯] JavaScript Scoping and Hoisting

    摘要:對(duì)于新手來(lái)說(shuō)是最令人困惑的部分之一。函數(shù)聲明通過(guò)的形式。很明顯的,語(yǔ)言自身定義和函數(shù)形參已經(jīng)處于作用域頂端。這就意味著,函數(shù)聲明比變量聲明具有更高的優(yōu)先級(jí)。但是這卻不意味著對(duì)這個(gè)名稱(chēng)的賦值無(wú)效,僅僅是聲明的部分會(huì)被忽略而已。 原文鏈接:JavaScript Scoping and Hoisting 你知道下面的JavaScript代碼執(zhí)行后會(huì)alert出什么值嗎? var foo = ...

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

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

0條評(píng)論

chunquedong

|高級(jí)講師

TA的文章

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