中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

vue多頁面開發和打包的示例分析

發布時間:2021-08-11 10:10:42 來源:億速云 閱讀:155 作者:小新 欄目:web開發

這篇文章主要介紹vue多頁面開發和打包的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

vue多頁面開發和打包的示例分析

前段時間做項目,技術棧是vue+webpack,主要就是官網首頁加后臺管理系統 根據當時情況,分析出三種方案

  1. 一個項目代碼里面嵌兩個spa應用(官網和后臺系統)

  2. 分開兩套項目源碼

  3. 一套項目源碼里面就一個spa應用

思考:

  1. 直接否定了一套項目源碼里一個spa應用(ui樣式會相互覆蓋,如果沒有代碼規范后期比較難維護)

  2. 兩套源碼的話,后臺可能開兩個端口,然后需要用nginx反向代理可能比較麻煩,而且前端開發也比較麻煩麻煩,畢竟需要維護兩個git倉庫,兩套git上線流程,可能會損耗很多時間。

  3. 對自己的技術(盲目)自信,也想嘗嘗鮮,分析出需求也不算很復雜。選了第一種方案,就是多個單頁面應用在一套源碼里面

上一張多頁面的結構圖

vue多頁面開發和打包的示例分析 

下載vue spa模板

npm install vue-cli -g
vue init webpack multiple-vue-amazing

改造多頁面應用

npm install glob --save-dev

修改src文件夾下面的目錄結構

vue多頁面開發和打包的示例分析 

在util.js里面加入

/* 這里是添加的部分 ---------------------------- 開始 */
// glob是webpack安裝時依賴的一個第三方模塊,還模塊允許你使用 *等符號, 例如lib/*.js就是獲取lib文件夾下的所有js后綴名的文件
var glob = require('glob')
// 頁面模板
var HtmlWebpackPlugin = require('html-webpack-plugin')
// 取得相應的頁面路徑,因為之前的配置,所以是src文件夾下的pages文件夾
var PAGE_PATH = path.resolve(__dirname, '../src/pages')
// 用于做相應的merge處理
var merge = require('webpack-merge')
//多入口配置
// 通過glob模塊讀取pages文件夾下的所有對應文件夾下的js后綴文件,如果該文件存在
// 那么就作為入口處理
exports.entries = function () {
 var entryFiles = glob.sync(PAGE_PATH + '/*/*.js')
 var map = {}
 entryFiles.forEach((filePath) => {
  var filename = filePath.substring(filePath.lastIndexOf('\/') + 1, filePath.lastIndexOf('.'))
  map[filename] = filePath
 })
 return map
}
//多頁面輸出配置
// 與上面的多頁面入口配置相同,讀取pages文件夾下的對應的html后綴文件,然后放入數組中
exports.htmlPlugin = function () {
 let entryHtml = glob.sync(PAGE_PATH + '/*/*.html')
 let arr = []
 entryHtml.forEach((filePath) => {
  let filename = filePath.substring(filePath.lastIndexOf('\/') + 1, filePath.lastIndexOf('.'))
  let conf = {
   // 模板來源
   template: filePath,
   // 文件名稱
   filename: filename + '.html',
   // 頁面模板需要加對應的js腳本,如果不加這行則每個頁面都會引入所有的js腳本
   chunks: ['manifest', 'vendor', filename],
   inject: true
  }
  if (process.env.NODE_ENV === 'production') {
   conf = merge(conf, {
    minify: {
     removeComments: true,
     collapseWhitespace: true,
     removeAttributeQuotes: true
    },
    chunksSortMode: 'dependency'
   })
  }
  arr.push(new HtmlWebpackPlugin(conf))
 })
 return arr
}
/* 這里是添加的部分 ---------------------------- 結束 */
webpack.base.conf.js 文件
/* 修改部分 ---------------- 開始 */
 entry: utils.entries(),
 /* 修改部分 ---------------- 結束 */
webpack.dev.conf.js 文件
/* 注釋這個區域的文件 ------------- 開始 */
 // new HtmlWebpackPlugin({
 // filename: 'index.html',
 // template: 'index.html',
 // inject: true
 // }),
 /* 注釋這個區域的文件 ------------- 結束 */
 new FriendlyErrorsPlugin()
 /* 添加 .concat(utils.htmlPlugin()) ------------------ */
 ].concat(utils.htmlPlugin())
webpack.prod.conf.js 文件
/* 注釋這個區域的內容 ---------------------- 開始 */
 // new HtmlWebpackPlugin({
 // filename: config.build.index,
 // template: 'index.html',
 // inject: true,
 // minify: {
 //  removeComments: true,
 //  collapseWhitespace: true,
 //  removeAttributeQuotes: true
 //  // more options:
 //  // https://github.com/kangax/html-minifier#options-quick-reference
 // },
 // // necessary to consistently work with multiple chunks via CommonsChunkPlugin
 // chunksSortMode: 'dependency'
 // }),
 /* 注釋這個區域的內容 ---------------------- 結束 */
 // copy custom static assets
 new CopyWebpackPlugin([
  {
  from: path.resolve(__dirname, '../static'),
  to: config.build.assetsSubDirectory,
  ignore: ['.*']
  }
 ])
 /* 該位置添加 .concat(utils.htmlPlugin()) ------------------- */
 ].concat(utils.htmlPlugin())

引入第三方ui庫

npm install element-ui bootstrap-vue --save

分別在不同的頁面引入不同的ui index.js

import BootstrapVue from 'bootstrap-vue'
Vue.use(BootstrapVue)

admin.js

import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
Vue.use(ElementUI)

上面多頁面的配置是參考網上的,而且網上的思路大都很相似,核心就是改多個entry,配置完成了之后,開發的時候也是發現不了問題的,然后大概就開發了一個月,開發完之后對官網進行性能分析時發現,webpack打包的vendor.js網絡加載時間特別長,導致首屏的白屏時間非常長,最終通過-webpack-bundle-analyzer分析得到了結論

npm run build --report

vue多頁面開發和打包的示例分析 

你會發現vendor.js包含了index.html和admin.html的共同部分,所以這個vendor包注定會很大很冗余

解決思路

既然是vendor過大引起加載速度慢,那就分離這個vendor就好了。我是這樣想的,把各個頁面中都使用到的第三方代碼提取至vendor.js中,然后各個頁面中用到的第三方代碼再打包成各自的vendor-x.js,例如現有頁面index.html、admin.html,則最終會打包出vendor.js、vendor-index.js、vendor-admin.js。

webpack.prod.conf.js 文件

new webpack.optimize.CommonsChunkPlugin({
  name: 'vendor-admin',
  chunks: ['vendor'],
  minChunks: function (module, count) {
  return (
   module.resource &&
   /\.js$/.test(module.resource) &&
   module.resource.indexOf(path.join(__dirname, '../node_modules')) === 0 &&
   module.resource.indexOf('element-ui') != -1
  )
  }
 }),
 new webpack.optimize.CommonsChunkPlugin({
  name: 'vendor-index',
  chunks: ['vendor'],
  minChunks: function (module, count) {
  return (
   module.resource &&
   /\.js$/.test(module.resource) &&
   module.resource.indexOf(path.join(__dirname, '../node_modules')) === 0 &&
   module.resource.indexOf('bootstrap-vue') != -1
  )
  }
 }),

再次分析,一切都很ok,vendor.js被分離成了vendor.js、vendor-index、vendor-admin.js

vue多頁面開發和打包的示例分析 

本來以為解決了CommonsChunkPlugin的分離vendor.js的問題,就可以了,然后打包出來發現index.html和admin.html都少了一個引入(各自對應的那個vendor-xx.js)

vue多頁面開發和打包的示例分析 

解決方案

這個問題其實就是HtmlWebpackPlugin的問題 把原來的 chunksSortMode: 'dependency'改成自定義函數的配置,如下

util.js文件

chunksSortMode: function (chunk1, chunk2) {
   var order1 = chunks.indexOf(chunk1.names[0])
   var order2 = chunks.indexOf(chunk2.names[0])
   return order1 - order2
  },

最終實現

  • 每個頁面加載各自的chunk

  • 每個頁面有不同的參數

  • 每個頁面能共享公共chunk

  • 瀏覽器緩存,性能更好

  • 如果還嫌慢的話,開啟gzip


感想

大功告成了,雖然配置看起來很簡單,不過我當時開發的時候,思考了很久,所以假如你CommonsChunkPlugin和HtmlWebpackPlugin不熟悉或者只會用別人第三方的配置表,估計會踩大坑,比如說,CommonsChunkPlugin不指定chunks,默認是什么?minChunks大多數人只會寫一個數值,然而自定義一個函數的寫法其實才是最強大的,根據我個人的經驗chunks結合minChunks自定義函數的寫法,能解決幾乎所有CommonsChunkPlugin靈異的事件。

以上是“vue多頁面開發和打包的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

vue
AI

淮阳县| 德令哈市| 忻州市| 鸡东县| 班戈县| 瑞昌市| 济南市| 乐平市| 龙川县| 多伦县| 轮台县| 土默特右旗| 洛扎县| 南宫市| 石棉县| 海晏县| 长垣县| 盐源县| 壶关县| 宿州市| 宜宾市| 荔波县| 宜州市| 景泰县| 探索| 容城县| 手游| 仲巴县| 类乌齐县| 神农架林区| 乐陵市| 鹤壁市| 兴隆县| 华坪县| 黔南| 保定市| 大姚县| 青浦区| 东乡族自治县| 潞西市| 海林市|