這篇文章主要介紹webpack實用小功能的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)提供從項目策劃、軟件開發(fā),軟件安全維護、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評估等整套的建站服務(wù),主營業(yè)務(wù)為網(wǎng)站設(shè)計制作、成都網(wǎng)站設(shè)計,成都app軟件開發(fā)公司以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)建站深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!webpack比較實用的功能
1.overlay
overlay屬于devServer的屬性,配置案例如下:
devServer: { overlay: { errors: true, warnings: true } }
配置很簡單,那它的作用是什么呢?overlay的作用是可以在瀏覽器打開的頁面顯示終端編譯時產(chǎn)生的錯誤。通過配置該屬性,以后在寫代碼的時候,編譯如果出錯了,我們就不需要打開終端看到底是什么報錯了,可以直接在頁面里看到錯誤,對于開發(fā)而言確實很方便。
2.require.ensure
相比較overlay,require.ensure可以的作用更加實用,上次講的vue2-webpack3我們配置的是多頁面的應(yīng)用,但是如果是SPA應(yīng)用呢?
我們最容易遇到的問題代碼全部打包在一個js里面,導(dǎo)致這個js過于龐大,最終導(dǎo)致應(yīng)用首次加載時等待時間過長,那么該怎么解決這個問題呢?require.ensure就是專門用來解決這個問題的。
該怎么使用?
使用起來也很簡單,只要按照下面的寫法來進行vue的router配置即可:
const Layout = require('../Layout') const Home = r => require.ensure([], () => r(require('../home'), home) export default [{ path: '/', component: Layout, children: [{ path: '', component: Home }] }]
可以看到require.ensure有三個參數(shù)
第一個參數(shù)的作用是配置依賴列表,被依賴的模塊會和當(dāng)前模塊打包到一起; 第二個參數(shù)是一個函數(shù),將要單獨打包的模塊傳入回調(diào)里; 第三個參數(shù)是chunkname,可用來配置js的文件名; 配置完了以后,當(dāng)我們加載這個頁面的時候,屬于每個頁面自己的代碼部分,就會單獨去加載了。
3.webpack-bundle-analyzer
這是一個webpack的插件,它的主要作用是用來分析我們模塊打包的資源情況,非常的直觀,也非常的實用,下面我們先看下它的效果圖:
那么該如何配置呢? 首先你得先install,然后配置如下:
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; plugins = [ new BundleAnalyzerPlugin({ // Can be `server`, `static` or `disabled`. // In `server` mode analyzer will start HTTP server to show bundle report. // In `static` mode single HTML file with bundle report will be generated. // In `disabled` mode you can use this plugin to just generate Webpack Stats JSON file by setting `generateStatsFile` to `true`. analyzerMode: 'server', // Host that will be used in `server` mode to start HTTP server. analyzerHost: '127.0.0.1', // Port that will be used in `server` mode to start HTTP server. analyzerPort: 8888, // Path to bundle report file that will be generated in `static` mode. // Relative to bundles output directory. reportFilename: 'report.html', // Module sizes to show in report by default. // Should be one of `stat`, `parsed` or `gzip`. // See "Definitions" section for more information. defaultSizes: 'parsed', // Automatically open report in default browser openAnalyzer: true, // If `true`, Webpack Stats JSON file will be generated in bundles output directory generateStatsFile: false, // Name of Webpack Stats JSON file that will be generated if `generateStatsFile` is `true`. // Relative to bundles output directory. statsFilename: 'stats.json', // Options for `stats.toJson()` method. // For example you can exclude sources of your modules from stats file with `source: false` option. // See more options here: https://github.com/webpack/webpack/blob/webpack-1/lib/Stats.js#L21 statsOptions: null, // Log level. Can be 'info', 'warn', 'error' or 'silent'. logLevel: 'info' }) ]
是不是很簡單卻很實用呢~
4.DllPlugin+DllReferencePlugin
在使用webpack開發(fā)的過程中,相信很多人都會覺得有時候項目啟動編譯時間等待太久了,為什么呢?因為當(dāng)項目慢慢龐大起來的時候,我們依賴的模塊越來越多,每次項目啟動編譯都需要全部編譯打包,所以自然會導(dǎo)致編譯時間偏長,那如何解決這個問題呢?
首先思路是這樣的,一般node_modules文件中的依賴,基本上是不會去做改變的,所以沒有必要每次都去進行打包,我們完全可以將這些依賴提前打包好,然后就可以一直使用了。
DllPlugin就是用來提前打包我們的依賴包的插件。DllPlugin分為兩個插件,一個是DllPlugin,另一個是DllReferencePlugin。
首先DllPlugin的作用是用來提前打包好依賴,步驟如下:
新建一個vendor.js,用來引入所有我們依賴的模塊:
import Vue from 'vue'; import ElementUI from 'element-ui'; import VouRouter from 'vue-router';
新建一個webpack.config.dll.js的配置文件,配置如下:
const path = require('path'); const webpack = require('webpack'); module.exports = { entry: { vendor: [path.resolve(__dirname, 'vendor')] }, output: { path: path.resolve(__dirname, './dll'), filename: 'dll.[name].js', library: '[name]' }, plugins: [ new webpack.DllPlugin({ path: path.join(__dirname, "./dll", "[name]-manifest.json"), name: "[name]" }) ], resolve: { extensions: ['js'] }
配置好了以后,就可以到終端里運行webpack --config webpack.config.dll.js了,然后就能在你的dist/dll目錄下看到一個dll.vendore.js和一個vendor-manifest.json文件,到此DllPlugin提取依賴的作用就完成了。
下面是DllReferencePlugin的配置,這個配置更簡單,找到項目原本的webpack.config.js文件,然后配置如下:
module.exports = { plugins: [ new webpack.DllReferencePlugin({ context: path.join(__dirname, "src"), manifest: require("./dll/vendor-manifest.json") }) ] }
這樣就都配置好了,但是這樣做還存在個問題,當(dāng)你運行項目時,會提示:
You are using the runtime-only build of Vue...
大概的意思就是說因為你使用了vue的template,使用的vue版本不對,所以我在webpack.config.dll.js里面對vue做如下設(shè)置:
alias: { 'vue$': 'vue/dist/vue.common.js' }
否則會默認打包vue.runtime.common.js,正確的應(yīng)該是打包vue.common.js這個文件。做了以上配置以后,本以為就OK了,但還是太天真,依舊還是報了一樣的錯誤。
然后我到webpack.config.js里面做了同樣的配置,結(jié)果就OK了。但是這會導(dǎo)致vue被打包了兩份,所以暫時只能放棄在vendor內(nèi)引入vue了,導(dǎo)致該問題的原因暫不明了。
以上是“webpack實用小功能的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。