亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue多頁面開發和打包正確處理方法

2019-11-19 13:59:24
字體:
來源:轉載
供稿:網友

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

  1. 一個項目代碼里面嵌兩個spa應用(官網和后臺系統)
  2. 分開兩套項目源碼
  3. 一套項目源碼里面就一個spa應用

思考:

  1. 直接否定了一套項目源碼里一個spa應用(ui樣式會相互覆蓋,如果沒有代碼規范后期比較難維護)
  2. 兩套源碼的話,后臺可能開兩個端口,然后需要用nginx反向代理可能比較麻煩,而且前端開發也比較麻煩麻煩,畢竟需要維護兩個git倉庫,兩套git上線流程,可能會損耗很多時間。
  3. 對自己的技術(盲目)自信,也想嘗嘗鮮,分析出需求也不算很復雜。選了第一種方案,就是多個單頁面應用在一套源碼里面

上一張多頁面的結構圖

 

下載vue spa模板

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

改造多頁面應用

npm install glob --save-dev

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

 

在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

 

你會發現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

 

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

 

解決方案

這個問題其實就是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多頁面開發和打包正確處理方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品在线播放| 57pao成人国产永久免费| 成人在线一区二区| 欧美大片在线看| 亚洲天堂av在线播放| 国产一区二区三区视频在线观看| 日韩美女视频中文字幕| 欧美午夜激情在线| 亚洲另类激情图| 亚洲18私人小影院| 国产精品高潮呻吟久久av无限| 欧美日韩人人澡狠狠躁视频| 亚洲最大的av网站| 精品无人国产偷自产在线| 亚洲成av人乱码色午夜| 精品一区二区电影| 欧美成人剧情片在线观看| 国产成人欧美在线观看| 欧美午夜片在线免费观看| 亚洲国产精品久久久久秋霞不卡| 在线不卡国产精品| 91精品久久久久久久久不口人| 欧美日韩在线视频观看| 精品av在线播放| 欧美理论电影在线观看| 国产精品一区二区久久久久| 国产一区二区黑人欧美xxxx| 久久亚洲精品国产亚洲老地址| 久久久久久97| 欧美日韩另类字幕中文| 日韩电影在线观看永久视频免费网站| 97视频com| 欧美性猛交xxxx偷拍洗澡| 91国产精品电影| 亚洲欧美中文字幕在线一区| 欧美—级a级欧美特级ar全黄| 亚洲色在线视频| 国产精品免费福利| 亚洲中国色老太| 北条麻妃99精品青青久久| 国产精品网站视频| 精品在线小视频| 亚洲欧美制服综合另类| 久久艳片www.17c.com| 国内免费久久久久久久久久久| 欧美高清视频在线| 日韩精品在线视频美女| 精品高清美女精品国产区| 国产欧美在线看| 国产精品欧美一区二区三区奶水| 国产欧美日韩丝袜精品一区| 日本久久久久久久久| 久久久精品在线观看| www.久久撸.com| 欧美黑人xxxⅹ高潮交| 欧美午夜精品伦理| 3344国产精品免费看| 欧美专区国产专区| 国内精品久久久久久中文字幕| 97久久超碰福利国产精品…| 国产亚洲欧洲高清一区| 狠狠色狠狠色综合日日五| 国产丝袜高跟一区| 亚洲精品一区二区在线| 亚洲女同精品视频| 91成人免费观看网站| 精品国产91乱高清在线观看| 成人两性免费视频| 欧美在线视频导航| 日韩美女免费线视频| 亚洲第一天堂无码专区| 亚洲美女视频网站| 欧美视频国产精品| 欧美性黄网官网| 欧美理论片在线观看| 日韩亚洲欧美中文高清在线| 国产午夜精品视频免费不卡69堂| 欧美高清不卡在线| 中文字幕亚洲天堂| 久久全球大尺度高清视频| 5278欧美一区二区三区| 国产精品91视频| 国产日韩欧美中文在线播放| 中文字幕av一区二区三区谷原希美| 日本午夜精品理论片a级appf发布| 精品国内自产拍在线观看| 色综合久久88| 亚洲欧美日韩精品久久| 国产成人av网| 国产99久久精品一区二区永久免费| 中文字幕日韩精品在线观看| 日韩精品久久久久久久玫瑰园| 色诱女教师一区二区三区| 国产suv精品一区二区| 最近中文字幕mv在线一区二区三区四区| 精品无人区太爽高潮在线播放| 国产欧美精品xxxx另类| 亚洲黄一区二区| 国产精品成人观看视频国产奇米| 欧美在线视频导航| 中文字幕精品—区二区| 国产精品日韩久久久久| 日韩视频永久免费观看| 亚洲色图18p| 日韩av在线网页| 亚洲欧美999| 国产中文字幕亚洲| 亚洲免费视频一区二区| 日韩av网站电影| 精品久久香蕉国产线看观看亚洲| 日本a级片电影一区二区| 欧美日韩在线视频一区| 高清欧美一区二区三区| 欧美激情xxxx性bbbb| 精品无人区乱码1区2区3区在线| 亚洲午夜女主播在线直播| 91久久久久久国产精品| 亚洲www视频| 超碰97人人做人人爱少妇| 亚洲女人天堂网| 欧美大片免费观看在线观看网站推荐| 亚洲精品一区二三区不卡| 中文.日本.精品| 日韩中文字幕网| 亚洲女人被黑人巨大进入al| 国产精品999| 亚洲欧美国产一本综合首页| 九九热视频这里只有精品| 51精品在线观看| 亚洲欧美变态国产另类| 亚洲一级片在线看| 久久亚洲国产精品成人av秋霞| 欧美极度另类性三渗透| 欧日韩不卡在线视频| 91久久久久久久久久久| 777国产偷窥盗摄精品视频| 欧美伦理91i| 成人免费自拍视频| 午夜精品久久久久久久久久久久| 亚洲视频第一页| 亚洲精品98久久久久久中文字幕| 欧洲成人在线观看| 国产成人精品a视频一区www| 日韩av在线高清| 国产视频观看一区| 亚洲第一偷拍网| 国产美女扒开尿口久久久| 日韩av电影免费观看高清| 日韩在线视频观看正片免费网站| 欧美大荫蒂xxx| 国产精品网红直播| 日韩美女福利视频| 在线播放日韩av| 欧美贵妇videos办公室| 奇门遁甲1982国语版免费观看高清| 91色在线观看| 55夜色66夜色国产精品视频| 91视频8mav| 69久久夜色精品国产7777| 亚洲精品视频免费在线观看| 国产亚洲精品久久久久久777| 这里只有精品在线观看| 精品国产视频在线| 欧美日韩在线影院|