首頁 > web前端 > js教程 > vue-cli多模組打包使用詳解

vue-cli多模組打包使用詳解

php中世界最好的语言
發布: 2018-05-14 11:06:50
原創
2744 人瀏覽過

這次帶給大家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模組,可以根據自己的專案配置更改,此處是以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中文網其它相關文章!

建議讀取:

bing Map使用步驟詳解

node token實作驗證

######################################## #

以上是vue-cli多模組打包使用詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
node.js - vue-cli無法建立專案。
來自於 1970-01-01 08:00:00
0
0
0
node.js - vue-cli安裝出錯
來自於 1970-01-01 08:00:00
0
0
0
javascript - vue-cli 本機介面轉送
來自於 1970-01-01 08:00:00
0
0
0
javascript - vue-cli npm run build編譯報錯
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板