溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么利用webpack4搭建一個組件庫

發布時間:2020-11-30 15:09:26 來源:億速云 閱讀:190 作者:Leah 欄目:開發技術

本篇文章為大家展示了怎么利用webpack4搭建一個組件庫,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

代碼分離

代碼分離方法有三種:

  • 入口起點:使用 entry 配置手動地分離代碼。

  • 防止重復:使用 SplitChunksPlugin 去重和分離 chunk。

  • 動態導入:通過模塊中的內聯函數調用來分離代碼。

動態導入(dynamic imports)

  • import()

  • require.ensure

預取/預加載模塊(prefetch/preload module)

webpack v4.6.0+ 添加了預取和預加載的支持。

在聲明 import 時,使用下面這些內置指令,可以讓 webpack 輸出 "resource hint(資源提示)",來告知瀏覽器:

  • prefetch(預取):將來某些導航下可能需要的資源

  • preload(預加載):當前導航下可能需要資源

配置項重點詳解

(1)mode: "pruduction"
啟用 minification(代碼壓縮) 和 tree shaking (usedExports:true)
自動指定DefinePlugin:process.env.NODE_ENV === 'production'

(2)devtool
source map 簡介

生產環境:source-map
開發環境:inline-source-map

(3)optimization
splitChunks

splitChunks: {
 chunks: 'all', // 提取公共模塊 loadash
 // 將第三方庫(library)(例如 lodash 或 react)提取到單獨的 vendor chunk 文件中,是比較推薦的做法
 // 利用 client 的長效緩存機制,命中緩存來消除請求,并減少向 server 獲取資源,同時還能保證 client 代碼和 server 代碼版本一致。
 cacheGroups: {
  vendor: {
   test: /[\\/]node_modules[\\/]/,
   name: 'vendors',
   chunks: 'all'
  }
 }
},

runtimeChunk

runtimeChunk: 'single' // 提取引導模板 將 runtime 代碼拆分為一個單獨的 chunk

(5)output

// filename: '[name].[contenthash].js', // content hash 內容變化才會變化
filename: 'webpack-numbers.js', 
path: path.resolve(__dirname, 'dist'),

// 暴露 library 這是庫名稱 import from 'webpackNumbers'
library: 'webpackNumbers', 
libraryTarget: 'umd'

(6)plugins

HashedModuleIdsPlugin

const { HashedModuleIdsPlugin } = require('webpack');

plugins: [
  // 不會因模塊增加和減少導致的模塊內容變化,增加長緩存命中機制
  new HashedModuleIdsPlugin()
],

BundleAnalyzerPlugin

分析打包代碼

const {BundleAnalyzerPlugin} = require('webpack-bundle-analyzer');

plugins: [
  new BundleAnalyzerPlugin()
]

上述內容就是怎么利用webpack4搭建一個組件庫,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女