摘要:澄清一個共同的誤解代碼分離不僅僅是抽出公共代碼把它們放進(jìn)一個共享的塊中。讓我們來使用來移除這個重復(fù)的部分。插件將會注意到我們已經(jīng)將分割成一個多帶帶的塊。并且從我們的主中刪除了這部分。
對于大型web app來說,如果把所有的文件都打包到一個文件中是非常低效的,特別是當(dāng)一些代碼塊只在某些特定的條件下被調(diào)用。webpack可以讓你的代碼庫分割成不同的塊(chucks),僅僅在需要的時候再加載。其他的一些打包工具叫它們圖層(layers), 卷(rollups) 或者 片段(fragments),這些特性被叫做代碼分離(code splitting)。
這是一個可選的屬性。你可以在你的代碼庫中定義分割點(diǎn)。webpack能幫你管理好依賴,輸出文件和運(yùn)行時。
澄清一個共同的誤解:代碼分離(code splitting)不僅僅是抽出公共代碼把它們放進(jìn)一個共享的塊(chuck)中。更重要的特性是代碼分離(code splitting)可以將代碼分割成按需加載的塊。這可以使項目初始化的時候只需要加載很少的代碼,當(dāng)應(yīng)用請求的時候再按需加載代碼。
有三種常用的代碼分離方法:
入口起點(diǎn): 使用entry選項手動分離代碼
防止重復(fù): 使用 CommonsChuckPlugin 來去重和分離代碼
動態(tài)導(dǎo)入: 在模塊內(nèi)部通過內(nèi)聯(lián)函數(shù)來調(diào)用代碼
入口這是迄今為止最簡單,最直觀的拆分代碼的方式。但是它是比較偏向手動并且有一些陷阱需要我們?nèi)プ⒁獾摹?匆豢次覀兪窃趺礃訌闹鱞uddle中分割其他模塊的。
projectwebpack-demo |- package.json |- webpack.config.js |- /dist |- /src |- index.js + |- another-module.js |- /node_modulesanother-module.js
import _ from "lodash"; console.log( _.join(["Another", "module", "loaded!"], " ") );webpack.config.js
const path = require("path"); const HTMLWebpackPlugin = require("html-webpack-plugin"); module.exports = { entry: { index: "./src/index.js", another: "./src/another-module.js" }, plugins: [ new HTMLWebpackPlugin({ title: "Code Splitting" }) ], output: { filename: "[name].bundle.js", path: path.resolve(__dirname, "dist") } };
這將會產(chǎn)生下面的build結(jié)果:
Hash: 309402710a14167f42a8 Version: webpack 2.6.1 Time: 570ms Asset Size Chunks Chunk Names index.bundle.js 544 kB 0 [emitted] [big] index another.bundle.js 544 kB 1 [emitted] [big] another [0] ./~/lodash/lodash.js 540 kB {0} {1} [built] [1] (webpack)/buildin/global.js 509 bytes {0} {1} [built] [2] (webpack)/buildin/module.js 517 bytes {0} {1} [built] [3] ./src/another-module.js 87 bytes {1} [built] [4] ./src/index.js 216 bytes {0} [built]
還記得我們提到的那些陷阱嘛?
如果入口文件中有任何重復(fù)的模塊,它們都會被包含在這些入口文件中。
它是不靈活的并且不能用內(nèi)在的應(yīng)用邏輯來動態(tài)分割代碼。
這兩點(diǎn)中的第一點(diǎn)絕對是我們例子的中的問題。像lodash也在./src/index.js中被導(dǎo)入,所以它會在兩個bundle中重復(fù)。讓我們來使用CommonsChunkPlugin來移除這個重復(fù)的部分。
阻止重復(fù)CommonsChunkPlugin插件允許我們抽出共同的依賴放在一個存在的入口chunk或者一個存在的new chunk里。讓我們使用這個插件去除上一個例子中重復(fù)的lodash依賴。
const path = require("path"); + const webpack = require("webpack"); const HTMLWebpackPlugin = require("html-webpack-plugin"); module.exports = { entry: { index: "./src/index.js", another: "./src/another-module.js" }, plugins: [ new HTMLWebpackPlugin({ title: "Code Splitting" + }) + }), + new webpack.optimize.CommonsChunkPlugin({ + name: "common" // Specify the common bundle"s name. + }) ], output: { filename: "[name].bundle.js", path: path.resolve(__dirname, "dist") } };
在這里使用commonsChunkPlugin,我們將會看到重讀的依賴會從我們的index.bundle.js文件中移除。插件將會注意到我們已經(jīng)將loadash分割成一個多帶帶的塊。并且從我們的主bundle中刪除了這部分。讓我們運(yùn)行npm run bulid來看看它是否起作用了。
Hash: 70a59f8d46ff12575481 Version: webpack 2.6.1 Time: 510ms Asset Size Chunks Chunk Names index.bundle.js 665 bytes 0 [emitted] index another.bundle.js 537 bytes 1 [emitted] another common.bundle.js 547 kB 2 [emitted] [big] common [0] ./~/lodash/lodash.js 540 kB {2} [built] [1] (webpack)/buildin/global.js 509 bytes {2} [built] [2] (webpack)/buildin/module.js 517 bytes {2} [built] [3] ./src/another-module.js 87 bytes {1} [built] [4] ./src/index.js 216 bytes {0} [built]
這里有一些社區(qū)提供的分割代碼的插件和加載器:
ExtractTextPlugin: 用來從主程序中分割出css
bundle-loader: 用來分離代碼并且懶加載結(jié)果bundles
Promise-loader: 和bundle-loader作用相同,但是它是使用promise
CommonsChunkPlugin使用explicit vendor chunks從核心應(yīng)用代碼中來分離vendor模塊
當(dāng)涉及到動態(tài)分割的時候,有兩種相似的技術(shù)被支持。第一個并且也是更完滿的方法是使用遵循ECMAScript規(guī)范的import語法來進(jìn)行動態(tài)導(dǎo)入。更老的一種是,webpack特殊的方法require.ensure。讓我們來試一試使用第一種方法。
import調(diào)用使用promise,如果你想在不支持promise的老舊瀏覽器上使用,請引入一個promise polyfill。
在我們開始之前,讓我們移除這個多余的entry和commonsChunkPlugin 從我們的配置文件中。因為它們在接下來的教學(xué)中已經(jīng)不再需要了。
webpack.config.js
const path = require("path"); - const webpack = require("webpack"); const HTMLWebpackPlugin = require("html-webpack-plugin"); module.exports = { entry: { + index: "./src/index.js" - index: "./src/index.js", - another: "./src/another-module.js" }, plugins: [ new HTMLWebpackPlugin({ title: "Code Splitting" - }), + }) - new webpack.optimize.CommonsChunkPlugin({ - name: "common" // Specify the common bundle"s name. - }) ], output: { filename: "[name].bundle.js", + chunkFilename: "[name].bundle.js", path: path.resolve(__dirname, "dist") } };
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/84865.html
摘要:代碼分離代碼分離是最受矚目的功能。下面有兩種代碼分離的技術(shù)。使用實(shí)現(xiàn)代碼分離是使用的方式實(shí)現(xiàn)靜待資源異步調(diào)用。通過添加,我們可以在代碼中打一個分離點(diǎn),可以以此建立一個獨(dú)立的包,包含這個點(diǎn)的所有代碼。 代碼分離(Code Splitting) 代碼分離是webpack最受矚目的功能。它允許你把你的代碼分成不同的部分分開打包,然后實(shí)現(xiàn)在需要的時候再進(jìn)行加載(按需加載提高速度)————例如用...
摘要:瀏覽器需要重新下載打包后的文件,即使文件的絕大部分都沒有變化。分離并且以來命名新的入口能夠緩和當(dāng)前的問題?,F(xiàn)在運(yùn)行綁定的檢查結(jié)果是只是被綁定到這個綁定文件中。 分離庫代碼Code Splitting - Libraries 這個在webpack2.x中文網(wǎng)已存在,點(diǎn)擊這里 讓我們想一個簡單的應(yīng)用——momentjs,他是一個事件格式化的庫。安裝moment. npm install -...
摘要:基于路由的異步組件加載本文章是一個額外的篇章,它可以在你的中,幫助加快初始的加載組件時間。但是,我們靜態(tài)地在頂部導(dǎo)入路由中的所有組件。當(dāng)然我們的程序是相當(dāng)小的,并且分離在各個部分的小組件,是不需要這樣子按需加載的。 基于 Create React App路由4.0的異步組件加載 本文章是一個額外的篇章,它可以在你的React app中,幫助加快初始的加載組件時間。當(dāng)然這個操作不是完全必...
摘要:結(jié)合上下文猜測應(yīng)該是說沙子同時漏完的意思。問題的焦點(diǎn)在于如何表示不同的排列狀態(tài)以及如何處理沙漏翻轉(zhuǎn)。上一篇完美洗牌完美洗牌下一篇糖果惡作劇本系列總目錄參見程序員的算法趣題詳細(xì)分析和全解程序員的算法趣題詳細(xì)分析和全解 目錄 1. 問題描述 1.1 原題的表述 2. 解題分析 2.1 轉(zhuǎn)換為線...
閱讀 3291·2021-11-25 09:43
閱讀 2093·2021-09-22 10:02
閱讀 3348·2021-09-06 15:00
閱讀 2305·2019-08-30 15:56
閱讀 2356·2019-08-30 15:54
閱讀 3233·2019-08-30 14:14
閱讀 2268·2019-08-29 17:25
閱讀 2909·2019-08-29 17:16