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

資訊專欄INFORMATION COLUMN

webpack 性能提速

JouyPub / 1182人閱讀

摘要:使用該插件帶來的好處提升打包速度和項(xiàng)目體積將入口的文件中所有公共的代碼提取出來,減少代碼體積同時(shí)提升打包速度。利用緩存機(jī)制依賴的公共模塊文件一般很少更改或者不會(huì)更改,這樣獨(dú)立模塊文件提取出可以長(zhǎng)期緩存。那么,下面就來開啟正確的打開方式。

按需引用 外部的組件按需引用

2.啟用happypack多核構(gòu)建項(xiàng)目

3.修改source-map配置

啟用DllPlugin和DllReferencePlugin預(yù)編譯庫文件

1、按需引用
1.1幾乎所有的第三方組件框架都會(huì)提供組件的按需引用方式,以iview為例,通過借助插件babel-plugin-import可以實(shí)現(xiàn)按需加載組件,減少文件體積,只需要修改.babelrc文件

npm install babel-plugin-import --save-dev

// .babelrc
{
  "plugins": [["import", {
    "libraryName": "iview",
    "libraryDirectory": "src/components"
  }]]
}
1.2然后這樣按需引入組件,就可以減小體積了
import { Button } from "iview"
Vue.component("Table", Table)

2、啟用happypack多核構(gòu)建項(xiàng)目
安裝happypack后,修改/build/webpack.base.conf.js文件即可

npm install happypack --save-dev

// /build/webpack.base.conf.js
const HappyPack = require("happypack")
const os = require("os")
const happyThreadPool = HappyPack.ThreadPool({ size: os.cpus().length })
// 增加HappyPack插件
plugins: [
    new HappyPack({
      id: "happy-babel-js",
      loaders: ["babel-loader?cacheDirectory=true"],
      threadPool: happyThreadPool,
    })
  ]
// 修改引入loader
{
    test: /.js$/,
    // loader: "babel-loader",
    loader: "happypack/loader?id=happy-babel-js", // 增加新的HappyPack構(gòu)建loader
    include: [resolve("src"), resolve("test")]
}

實(shí)現(xiàn)js緩存

webpack插件CommonsChunkPlugin的主要作用是抽取webpack項(xiàng)目入口chunk的公共部分,具體的用法就不做過多介紹,不太了解可以參考webpack官網(wǎng)介紹;

該插件是webpack項(xiàng)目常用的一個(gè)優(yōu)化功能,幾乎在每個(gè)webpack項(xiàng)目中都會(huì)用到。使用該插件帶來的好處:

提升webpack打包速度和項(xiàng)目體積:將webpack入口的chunk文件中所有公共的代碼提取出來,減少代碼體積;同時(shí)提升webpack打包速度。

利用緩存機(jī)制:依賴的公共模塊文件一般很少更改或者不會(huì)更改,這樣獨(dú)立模塊文件提取出可以長(zhǎng)期緩存。

但是在項(xiàng)目中,若插件打開方式不正確的話,上面的第二點(diǎn)其實(shí)是無法實(shí)現(xiàn),因?yàn)檫@種情況下:

沒有被修改過的公有代碼或庫代碼打包出的Entry Chunk,會(huì)隨著其他業(yè)務(wù)代碼的變化而變化,導(dǎo)致頁面上的長(zhǎng)緩存機(jī)制失效。

那么,下面就來開啟CommonsChunkPlugin正確的打開方式。

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

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

相關(guān)文章

  • webpack 性能提速

    摘要:使用該插件帶來的好處提升打包速度和項(xiàng)目體積將入口的文件中所有公共的代碼提取出來,減少代碼體積同時(shí)提升打包速度。利用緩存機(jī)制依賴的公共模塊文件一般很少更改或者不會(huì)更改,這樣獨(dú)立模塊文件提取出可以長(zhǎng)期緩存。那么,下面就來開啟正確的打開方式。 按需引用 外部的組件按需引用 2.啟用happypack多核構(gòu)建項(xiàng)目 3.修改source-map配置 啟用DllPlugin和DllReferen...

    Reducto 評(píng)論0 收藏0
  • webpack 性能提速

    摘要:使用該插件帶來的好處提升打包速度和項(xiàng)目體積將入口的文件中所有公共的代碼提取出來,減少代碼體積同時(shí)提升打包速度。利用緩存機(jī)制依賴的公共模塊文件一般很少更改或者不會(huì)更改,這樣獨(dú)立模塊文件提取出可以長(zhǎng)期緩存。那么,下面就來開啟正確的打開方式。 按需引用 外部的組件按需引用 2.啟用happypack多核構(gòu)建項(xiàng)目 3.修改source-map配置 啟用DllPlugin和DllReferen...

    BWrong 評(píng)論0 收藏0
  • webpack4 配置解析和實(shí)戰(zhàn)

    摘要:特性比較熱門的兩大特性,零配置和速度快號(hào)稱提速上限一般情況下,相比于低版本,場(chǎng)景下第三方依賴打包速度和場(chǎng)景下本地服務(wù)首次啟動(dòng)速度都得到顯著提升零配置通過指定當(dāng)前場(chǎng)景為開發(fā)模式還是生產(chǎn)模式,自動(dòng)設(shè)置好當(dāng)前場(chǎng)景的默認(rèn)配置,用戶即可馬上使用,不需 webpack4特性 webpack4比較熱門的兩大特性,零配置和速度快(號(hào)稱提速上限98%) 一般情況下,webpack4相比于低版本,prod...

    王笑朝 評(píng)論0 收藏0
  • 開發(fā)工具心得:如何 10 倍提高你的 Webpack 構(gòu)建效率

    摘要:在項(xiàng)目架構(gòu)中這兩個(gè)東西基本成為了標(biāo)配,但的模塊必須在使用前經(jīng)過的構(gòu)建后文稱為才能在瀏覽器端使用,而每次修改也都需要重新構(gòu)建后文稱為才能生效,如何提高的構(gòu)建效率成為了提高開發(fā)效率的關(guān)鍵之一。 0. 前言 showImg(https://segmentfault.com/img/remote/1460000005770045); 圖1:ES6 + Webpack + React + Bab...

    用戶83 評(píng)論0 收藏0

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

0條評(píng)論

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