這次為大家帶來怎樣使用vue-cli擴展多模組打包,使用vue-cli擴展多模組打包的注意事項有哪些,下面就是實戰案例,一起來看一下。
場景
在實際的專案開發中會出現這樣的場景,專案中需要多個模組(單頁或多頁應用程式)配合使用的情況,而vue-cli預設只提供了單入口打包,所以就想到對vue-cli進行擴充
#實作
首先得知道webpack是提供了多入口打包,那就可以從這裡開始改造
新建build/entry.js
const path = require('path') const fs = require('fs') const moduleDir = path.resolve(dirname, '../src/modules') let entryObj = {} let moduleItems = fs.readdirSync(moduleDir) moduleItems.forEach(item => { entryObj[`${item}`] = `./src/modules/${item}/main.js` }) module.exports = entryObj
這裡用到了nodejs的fs和path模組,可以查看文檔http://nodejs.cn/api/ fs.html,http://nodejs.cn/api/path.html,可以根據自己的專案配置更改,此處是以src/modules/資料夾下的目錄作為模組,每個模組中都有一個main .js作為入口檔案
修改build/webpack.base.conf.js中entry
const entryObj = require('./entry') module.exports = { entry: entryObj }
接下來就是如何將打包好的檔案注入到html中,這裡利用html-webpack-plugin外掛程式來解決這個問題,首先你需要有一個html的模板文件,然後在webpack配置中更改預設的html-webpack-plugin外掛程式配置
新增build/plugins.js
const HtmlWebpackPlugin = require('html-webpack-plugin') let configPlugins = [] Object.keys(entryObj).forEach(item => { configPlugins.push(new HtmlWebpackPlugin( { filename: '../dist/' + item + '.html', template: path.resolve(dirname, '../index.html'), chunks: [item] } )) }) module.exports = configPlugins
修改build/webpack.dev.conf.js配置
module.exports = { plugins: configPlugins }
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是怎麼使用vue-cli擴充多模組打包的詳細內容。更多資訊請關注PHP中文網其他相關文章!