成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

webpack常用構(gòu)建優(yōu)化策略小結(jié)

簡介

建網(wǎng)站原本是網(wǎng)站策劃師、網(wǎng)絡(luò)程序員、網(wǎng)頁設(shè)計師等,應(yīng)用各種網(wǎng)絡(luò)程序開發(fā)技術(shù)和網(wǎng)頁設(shè)計技術(shù)配合操作的協(xié)同工作。創(chuàng)新互聯(lián)公司專業(yè)提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作,網(wǎng)頁設(shè)計,網(wǎng)站制作(企業(yè)站、響應(yīng)式網(wǎng)站、電商門戶網(wǎng)站)等服務(wù),從網(wǎng)站深度策劃、搜索引擎友好度優(yōu)化到用戶體驗的提升,我們力求做到極致!

讀了《深入淺出webpack》總結(jié)一下常用的webpack的構(gòu)建優(yōu)化策略,可通過以下手段來提升項目構(gòu)建時的速度

更精準的loader規(guī)則

將loader規(guī)則寫清楚

僅讓需要處理的文件,進入loader處理環(huán)節(jié),如下

  rules: [{
   // 正則盡量準確
   test: /\.js$/,
   // 使用緩存,緩存后在文件未改變時編譯會更快(緩存查找原理見補充1)
   use: ['babel-loader?cacheDirectory'],
   // 指定需要處理的目錄
   include: path.resolve(__dirname, 'src')
   // 理論上只有include就夠了,但是某些情況需要排除文件的時候可以用這個,排除不需要處理文件
   // exclude: []
  }]

更精準的查找目錄

將查找路徑設(shè)置精確

理論上我們項目的第三方依賴均應(yīng)在自己的工程的node_modules下,所以我們可以設(shè)置查找目錄,減少node的默認查找(默認查找方式見補充2)

module.exports = {
  resolve: {
    // 指定當前目錄下的node_modules目錄
    modules: [path.resolve(__dirname, 'node_modules')]
  }
}

更精準的擴展名

數(shù)量更多類型的文件盡量放在前面

平時寫代碼,我們都習慣直接寫文件名,而不去寫擴展名,那么解析則按照下面屬性進行解析

module.exports = {
  extensions: ['.js', '.jsx', '.ts', '.tsx'],
}

默認值

extensions: [".js", ".json"]

使用動態(tài)鏈接庫預編譯大模塊

使用動態(tài)鏈接庫,提前編譯大模塊

原理請見補充3

新建一個文件webpack_dll.config.js,內(nèi)容如下

const path = require('path');
const webpack = require('webpack');

// 復用的大模塊放在這里,這樣每次都不需要重新編譯了
const vendors = [
 'react',
 'react-dom',
 'lodash'
];

module.exports = {
 mode: 'development',
 output: {
  path: path.resolve(__dirname, './dist'),
  filename: '[name].js',
  library: '[name]',
 },
 entry: {
  vendors,
 },
 plugins: [
  new webpack.DllPlugin({
   path: path.resolve(__dirname, './dist/manifest.json'),
   name: '[name]',
  }),
 ],
};

執(zhí)行webpack --config webpack_dll.config.js進行首次編譯(如果更新版本需要再次編譯)

然后在你的webpack配置文件中引入manifest.json

 plugins: [
  new webpack.DllReferencePlugin({
   manifest: require('./dist/manifest.json')
  })
 ],

多進程處理文件

使用HappyPack同時處理多個loader編譯任務(wù)

為了發(fā)揮多核CPU電腦的功能,利用HappyPack將任務(wù)分發(fā)給多個子進程并發(fā)執(zhí)行

const path = require('path');
const HappyPack = require('happypack');
// 共享5個進程池
const happyThreadPool = HappyPack.ThreadPool({ size: 5 });

module.exports = {
 entry: './src/index.js',
 output: {
  filename: 'bundle.js',
  path: path.resolve(__dirname, 'dist'),
 },
 module: {
  // noParse: [/react\.production\.min\.js$/],
  rules: [{
   test: /\.js$/,
   // 和下面插件id一直,happypack才可以找到
   use: ['happypack/loader?id=babel'],
   include: path.resolve(__dirname, 'src')
  }]
 },
 plugins: [
  // 插件可以實例化多個
  new HappyPack({
   // 與上面對應(yīng)
   id: 'babel',
   // 實際要使用的loader
   loaders: ['babel-loader?cacheDirectory'],
   // 默認開啟進程數(shù)
   threads: 3,
   // 是否允許happyPack打印日志
   verbose: true,
   // 共享進程數(shù),如果你使用超過一個happyplugin,官方建議共享進程池
   threadPool: happyThreadPool
  })
 ],
};

原理見補充4

多進程壓縮文件

使用ParallelUglifyPlugin多進程同時壓縮文件

ParallelUglifyPlugin是在UglifyJS基礎(chǔ)上,增加了多進出處理的能力,加快了壓縮速度

import ParallelUglifyPlugin from 'webpack-parallel-uglify-plugin';
 
module.exports = {
 plugins: [
  new ParallelUglifyPlugin({
   test,
   include,
   exclude,
   cacheDir,
   workerCount,
   sourceMap,
   uglifyJS: {
   },
   uglifyES: {
   }
  }),
 ],
};

減少監(jiān)聽文件

減少監(jiān)聽文件

原理見補充5

當我們使用webpack的watch功能進行文件監(jiān)聽時,更好的方式是控制監(jiān)聽目錄,如下,排除node_modules減少對該目錄監(jiān)聽,減少編譯所需要循環(huán)的文件,提高檢查速度

module.export = {
  watchOptions: {
    ignored: /node_modules/
  }
}

其他沒那么重要的優(yōu)化

更精準的mainFields

默認的這個值查找方式見官網(wǎng)點擊此處

看了下react和lodash,只有一個main,目前來看使用es6看來還不普遍,所以這個值目前可能不太重要

module.exports = {
  resolve: {
    mainFields: ['main']
  }
}

第三方庫映射

為什么這個不重要,我發(fā)現(xiàn)react直接導出的index.js則是根據(jù)環(huán)境判斷使用哪份代碼,目測來看并不需要進行循環(huán)依賴的處理

通過依賴,則可以直接使用打包后代碼,而不需webpack去循環(huán)依賴

 resolve: {
  mainFields: ["main"],
  alias: {
   'react': path.resolve(__dirname, './node_modules/react/cjs/react.production.min.js')
  }
 }

不使用inline模式的devServer

原理見補充6

默認情況下,應(yīng)用程序啟用內(nèi)聯(lián)模式(inline mode)。這意味著一段處理實時重載的腳本被插入到你的包(bundle)中,并且構(gòu)建消息將會出現(xiàn)在瀏覽器控制臺。

當使用inline模式時,devServer會向每個Chunk中注入一段重載的腳本代碼,但是其實一個頁面只需要一次,所以當Chunk過多時,可以將inline設(shè)置為false

module.export = {
  devServer: {
    inline: false
  }
}

補充

補充1-cacheDirectory原理

當有設(shè)置cacheDirectory時,指定的目錄將用來緩存loader的執(zhí)行結(jié)果。之后的 webpack 構(gòu)建,將會嘗試讀取緩存,來避免在每次執(zhí)行時,可能產(chǎn)生的、高性能消耗的Babel重新編譯過程。如果設(shè)置了一個空值 (loader: 'babel-loader?cacheDirectory') 或者 true (loader: babel-loader?cacheDirectory=true),loader 將使用默認的緩存目錄 node_modules/.cache/babel-loader,如果在任何根目錄下都沒有找到 node_modules 目錄,將會降級回退到操作系統(tǒng)默認的臨時文件目錄。

補充2-node的默認查找方式

  • 查找當前目錄下的node_modules目錄,看是否有匹配項,如有,命中文件
  • 尋找父目錄的下的node_modules,如有,命中文件
  • 按照這個規(guī)則一直往父目錄搜索直到到根目錄下的node_modules

補充3-動態(tài)鏈接庫思想

大量項目中可以復用的模塊只需要被編譯一次,在之后的構(gòu)建過程中被動態(tài)鏈接庫包含的模塊將不會重新編譯,而是直接使用動態(tài)鏈接庫中的代碼。(注:如果升級依賴的模塊版本,需要重新編譯動態(tài)鏈接庫)

補充4-HappyPack原理

webpack構(gòu)建中,需要大量的loader轉(zhuǎn)換操作,很耗時,由于nodejs是單線程的,如果想更好利用cpu的多核能力,可以開啟多個進程,同時對文件進行處理;可以看到在配置文件中,我們每次將文件交給happypack-loader去處理,然后由happypack去調(diào)度來執(zhí)行文件的處理(happypack采用哪個loaders進行處理,是通過id知道的)

補充5-文件監(jiān)聽原理

webpack會從入口觸發(fā),將所有的依賴項放到一個list里邊,然后每次修改文件內(nèi)容,回去遍歷整個list里邊的文件,看是否有編輯時間的變化,如果有的話則進行編譯

補充6-自動刷新原理

  • 向要開發(fā)的網(wǎng)頁中注入代理客戶端代碼,通過代理客戶端去刷新整個頁面(默認)
  • 將要開發(fā)的網(wǎng)頁放進一個iframe,通過刷新iframe去看刷新效果

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)站標題:webpack常用構(gòu)建優(yōu)化策略小結(jié)
路徑分享:http://jinyejixie.com/article18/pgeedp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、云服務(wù)器、定制開發(fā)、搜索引擎優(yōu)化定制網(wǎng)站、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
德州市| 长武县| 永康市| 凤庆县| 南靖县| 开原市| 抚顺县| 新竹市| 库车县| 中方县| 徐州市| 苏尼特右旗| 嘉祥县| 华阴市| 巴彦淖尔市| 西乌| 灵宝市| 迭部县| 东丰县| 郸城县| 乌什县| 乌恰县| 沁水县| 海宁市| 鹰潭市| 扬州市| 洪泽县| 芮城县| 正镶白旗| 潜山县| 辽中县| 张家川| 高台县| 石渠县| 济源市| 米泉市| 紫金县| 四子王旗| 玉门市| 即墨市| 安国市|