webpack4從0搭建組件庫的實現(xiàn)
代碼分離
代碼分離方法有三種:
- 入口起點:使用 entry 配置手動地分離代碼。
- 防止重復(fù):使用 SplitChunksPlugin 去重和分離 chunk。
- 動態(tài)導(dǎo)入:通過模塊中的內(nèi)聯(lián)函數(shù)調(diào)用來分離代碼。
動態(tài)導(dǎo)入(dynamic imports)
- import()
- require.ensure
預(yù)取/預(yù)加載模塊(prefetch/preload module)
webpack v4.6.0+ 添加了預(yù)取和預(yù)加載的支持。
在聲明 import 時,使用下面這些內(nèi)置指令,可以讓 webpack 輸出 "resource hint(資源提示)",來告知瀏覽器:
- prefetch(預(yù)取):將來某些導(dǎo)航下可能需要的資源
- preload(預(yù)加載):當(dāng)前導(dǎo)航下可能需要資源
配置項重點詳解
(1)mode: "pruduction"
啟用 minification(代碼壓縮) 和 tree shaking (usedExports:true)
自動指定DefinePlugin:process.env.NODE_ENV === 'production'
(2)devtool
source map 簡介
生產(chǎn)環(huán)境:source-map
開發(fā)環(huán)境:inline-source-map
(3)optimization
splitChunks
splitChunks: {
chunks: 'all', // 提取公共模塊 loadash
// 將第三方庫(library)(例如 lodash 或 react)提取到單獨的 vendor chunk 文件中,是比較推薦的做法
// 利用 client 的長效緩存機(jī)制,命中緩存來消除請求,并減少向 server 獲取資源,同時還能保證 client 代碼和 server 代碼版本一致。
cacheGroups: {
vendor: {
test: /[\\/]node_modules[\\/]/,
name: 'vendors',
chunks: 'all'
}
}
},
runtimeChunk
runtimeChunk: 'single' // 提取引導(dǎo)模板 將 runtime 代碼拆分為一個單獨的 chunk
(5)output
// filename: '[name].[contenthash].js', // content hash 內(nèi)容變化才會變化 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: [
// 不會因模塊增加和減少導(dǎo)致的模塊內(nèi)容變化,增加長緩存命中機(jī)制
new HashedModuleIdsPlugin()
],
BundleAnalyzerPlugin
分析打包代碼
const {BundleAnalyzerPlugin} = require('webpack-bundle-analyzer');
plugins: [
new BundleAnalyzerPlugin()
]
到此這篇關(guān)于webpack4從0搭建組件庫的實現(xiàn)的文章就介紹到這了,更多相關(guān)webpack4搭建組件庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于chosen插件實現(xiàn)人員選擇樹搜索自動篩選功能
這篇文章主要介紹了基于chosen插件實現(xiàn)人員選擇樹搜索自動篩選功能的相關(guān)資料,需要的朋友可以參考下2016-09-09
uni-app小程序沉浸式導(dǎo)航實現(xiàn)的全過程
在跨端項目開發(fā)中,uniapp是個不錯的框架,下面這篇文章主要給大家介紹了關(guān)于uni-app小程序沉浸式導(dǎo)航實現(xiàn)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10
新手學(xué)習(xí)前端之js模仿淘寶主頁網(wǎng)站
淘寶網(wǎng)大家在熟悉不過了,那么淘寶網(wǎng)首頁模板是怎么做的呢?今天小編抽時間給大家分享新手學(xué)習(xí)前端之js模仿淘寶主頁網(wǎng)站的相關(guān)資料,需要的朋友可以參考下2016-10-10
JavaScript數(shù)據(jù)結(jié)構(gòu)之雙向鏈表定義與使用方法示例
這篇文章主要介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)之雙向鏈表定義與使用方法,簡單介紹了雙向鏈表的原理,并結(jié)合實例形式分析了雙向鏈表的定義與使用方法,需要的朋友可以參考下2017-10-10

