亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue多頁(yè)面開(kāi)發(fā)和打包正確處理方法

 更新時(shí)間:2018年04月20日 14:11:06   作者:乘風(fēng)gg  
這篇文章主要介紹了vue多頁(yè)面開(kāi)發(fā)和打包的正確處理方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

前段時(shí)間做項(xiàng)目,技術(shù)棧是vue+webpack,主要就是官網(wǎng)首頁(yè)加后臺(tái)管理系統(tǒng) 根據(jù)當(dāng)時(shí)情況,分析出三種方案

  1. 一個(gè)項(xiàng)目代碼里面嵌兩個(gè)spa應(yīng)用(官網(wǎng)和后臺(tái)系統(tǒng))
  2. 分開(kāi)兩套項(xiàng)目源碼
  3. 一套項(xiàng)目源碼里面就一個(gè)spa應(yīng)用

思考:

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

上一張多頁(yè)面的結(jié)構(gòu)圖

 

下載vue spa模板

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

改造多頁(yè)面應(yīng)用

npm install glob --save-dev

修改src文件夾下面的目錄結(jié)構(gòu)

 

在util.js里面加入

/* 這里是添加的部分 ---------------------------- 開(kāi)始 */
// glob是webpack安裝時(shí)依賴的一個(gè)第三方模塊,還模塊允許你使用 *等符號(hào), 例如lib/*.js就是獲取lib文件夾下的所有js后綴名的文件
var glob = require('glob')
// 頁(yè)面模板
var HtmlWebpackPlugin = require('html-webpack-plugin')
// 取得相應(yīng)的頁(yè)面路徑,因?yàn)橹暗呐渲?,所以是src文件夾下的pages文件夾
var PAGE_PATH = path.resolve(__dirname, '../src/pages')
// 用于做相應(yīng)的merge處理
var merge = require('webpack-merge')
//多入口配置
// 通過(guò)glob模塊讀取pages文件夾下的所有對(duì)應(yīng)文件夾下的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
}
//多頁(yè)面輸出配置
// 與上面的多頁(yè)面入口配置相同,讀取pages文件夾下的對(duì)應(yīng)的html后綴文件,然后放入數(shù)組中
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 = {
   // 模板來(lái)源
   template: filePath,
   // 文件名稱
   filename: filename + '.html',
   // 頁(yè)面模板需要加對(duì)應(yīng)的js腳本,如果不加這行則每個(gè)頁(yè)面都會(huì)引入所有的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
}
/* 這里是添加的部分 ---------------------------- 結(jié)束 */
webpack.base.conf.js 文件
/* 修改部分 ---------------- 開(kāi)始 */
 entry: utils.entries(),
 /* 修改部分 ---------------- 結(jié)束 */
webpack.dev.conf.js 文件
/* 注釋這個(gè)區(qū)域的文件 ------------- 開(kāi)始 */
 // new HtmlWebpackPlugin({
 // filename: 'index.html',
 // template: 'index.html',
 // inject: true
 // }),
 /* 注釋這個(gè)區(qū)域的文件 ------------- 結(jié)束 */
 new FriendlyErrorsPlugin()
 /* 添加 .concat(utils.htmlPlugin()) ------------------ */
 ].concat(utils.htmlPlugin())
webpack.prod.conf.js 文件
/* 注釋這個(gè)區(qū)域的內(nèi)容 ---------------------- 開(kāi)始 */
 // 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'
 // }),
 /* 注釋這個(gè)區(qū)域的內(nèi)容 ---------------------- 結(jié)束 */
 // copy custom static assets
 new CopyWebpackPlugin([
  {
  from: path.resolve(__dirname, '../static'),
  to: config.build.assetsSubDirectory,
  ignore: ['.*']
  }
 ])
 /* 該位置添加 .concat(utils.htmlPlugin()) ------------------- */
 ].concat(utils.htmlPlugin())

引入第三方ui庫(kù)

npm install element-ui bootstrap-vue --save

分別在不同的頁(yè)面引入不同的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)

上面多頁(yè)面的配置是參考網(wǎng)上的,而且網(wǎng)上的思路大都很相似,核心就是改多個(gè)entry,配置完成了之后,開(kāi)發(fā)的時(shí)候也是發(fā)現(xiàn)不了問(wèn)題的,然后大概就開(kāi)發(fā)了一個(gè)月,開(kāi)發(fā)完之后對(duì)官網(wǎng)進(jìn)行性能分析時(shí)發(fā)現(xiàn),webpack打包的vendor.js網(wǎng)絡(luò)加載時(shí)間特別長(zhǎng),導(dǎo)致首屏的白屏?xí)r間非常長(zhǎng),最終通過(guò)-webpack-bundle-analyzer分析得到了結(jié)論

npm run build --report

 

你會(huì)發(fā)現(xiàn)vendor.js包含了index.html和admin.html的共同部分,所以這個(gè)vendor包注定會(huì)很大很冗余

解決思路

既然是vendor過(guò)大引起加載速度慢,那就分離這個(gè)vendor就好了。我是這樣想的,把各個(gè)頁(yè)面中都使用到的第三方代碼提取至vendor.js中,然后各個(gè)頁(yè)面中用到的第三方代碼再打包成各自的vendor-x.js,例如現(xiàn)有頁(yè)面index.html、admin.html,則最終會(huì)打包出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

 

本來(lái)以為解決了CommonsChunkPlugin的分離vendor.js的問(wèn)題,就可以了,然后打包出來(lái)發(fā)現(xiàn)index.html和admin.html都少了一個(gè)引入(各自對(duì)應(yīng)的那個(gè)vendor-xx.js)

 

解決方案

這個(gè)問(wèn)題其實(shí)就是HtmlWebpackPlugin的問(wèn)題 把原來(lái)的 chunksSortMode: 'dependency'改成自定義函數(shù)的配置,如下

util.js文件

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

最終實(shí)現(xiàn)

  • 每個(gè)頁(yè)面加載各自的chunk
  • 每個(gè)頁(yè)面有不同的參數(shù)
  • 每個(gè)頁(yè)面能共享公共chunk
  • 瀏覽器緩存,性能更好
  • 如果還嫌慢的話,開(kāi)啟gzip

感想

大功告成了,雖然配置看起來(lái)很簡(jiǎn)單,不過(guò)我當(dāng)時(shí)開(kāi)發(fā)的時(shí)候,思考了很久,所以假如你CommonsChunkPlugin和HtmlWebpackPlugin不熟悉或者只會(huì)用別人第三方的配置表,估計(jì)會(huì)踩大坑,比如說(shuō),CommonsChunkPlugin不指定chunks,默認(rèn)是什么?minChunks大多數(shù)人只會(huì)寫(xiě)一個(gè)數(shù)值,然而自定義一個(gè)函數(shù)的寫(xiě)法其實(shí)才是最強(qiáng)大的,根據(jù)我個(gè)人的經(jīng)驗(yàn)chunks結(jié)合minChunks自定義函數(shù)的寫(xiě)法,能解決幾乎所有CommonsChunkPlugin靈異的事件。

總結(jié)

以上所述是小編給大家介紹的vue多頁(yè)面開(kāi)發(fā)和打包正確處理方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Vue?element-ui?el-cascader?只能末級(jí)多選問(wèn)題

    Vue?element-ui?el-cascader?只能末級(jí)多選問(wèn)題

    這篇文章主要介紹了Vue?element-ui?el-cascader?只能末級(jí)多選問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue引入css文件導(dǎo)致全局污染的問(wèn)題

    vue引入css文件導(dǎo)致全局污染的問(wèn)題

    這篇文章主要介紹了vue引入css文件導(dǎo)致全局污染的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue+watermark-dom實(shí)現(xiàn)頁(yè)面水印效果(示例代碼)

    vue+watermark-dom實(shí)現(xiàn)頁(yè)面水印效果(示例代碼)

    watermark.js 是基于 DOM 對(duì)象實(shí)現(xiàn)的 BS 系統(tǒng)的水印,確保系統(tǒng)保密性,安全性,降低數(shù)據(jù)泄密風(fēng)險(xiǎn),簡(jiǎn)單輕量,支持多屬性配置,本文將通過(guò) vue 結(jié)合 watermark-dom 庫(kù),教大家實(shí)現(xiàn)簡(jiǎn)單而有效的頁(yè)面水印效果,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • 使用Element-UI的NavMenu如何隱藏自帶的小箭頭

    使用Element-UI的NavMenu如何隱藏自帶的小箭頭

    這篇文章主要介紹了使用Element-UI的NavMenu如何隱藏自帶的小箭頭問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue在頁(yè)面中如何使用window全局變量

    vue在頁(yè)面中如何使用window全局變量

    這篇文章主要介紹了vue在頁(yè)面中如何使用window全局變量問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue內(nèi)存泄漏的識(shí)別和解決方案

    Vue內(nèi)存泄漏的識(shí)別和解決方案

    Vue是人氣爆棚且地表最強(qiáng)的JS(JavaScript)框架,祂允許我們構(gòu)建動(dòng)態(tài)交互式的Web App,然但是,和任何軟件雷同,Vue App偶爾會(huì)遭遇內(nèi)存泄漏,導(dǎo)致性能暴跌和意外行為,今天,我們將深入Vue App內(nèi)存泄漏的原因,并探討識(shí)別和修復(fù)這些問(wèn)題的錦囊妙計(jì)
    2023-11-11
  • Vue3.0組件通信mitt源碼ts實(shí)例解析

    Vue3.0組件通信mitt源碼ts實(shí)例解析

    這篇文章主要為大家介紹了Vue3.0組件通信mitt源碼ts實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • element-ui 插槽自定義樣式居中效果實(shí)現(xiàn)思路

    element-ui 插槽自定義樣式居中效果實(shí)現(xiàn)思路

    這篇文章主要介紹了element-ui 插槽自定義樣式居中效果,簡(jiǎn)單來(lái)講實(shí)現(xiàn)思路是通過(guò)template標(biāo)簽可理解為一個(gè)內(nèi)嵌組件,寬高重新定義,可在自定義內(nèi)容外層套一層盒子,讓盒子占滿所有空間,再使用flex讓內(nèi)部元素居中,需要的朋友可以參考下
    2024-07-07
  • Vue打包后出現(xiàn)一些map文件的解決方法

    Vue打包后出現(xiàn)一些map文件的解決方法

    本篇文章主要介紹了Vue打包后出現(xiàn)一些map文件的解決方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • 詳解vue中v-for和v-if一起使用的替代方法template

    詳解vue中v-for和v-if一起使用的替代方法template

    這篇文章主要介紹了vue中v-for和v-if一起使用的替代方法template,使用的版本是vue?2.9.6和element-ui:?2.15.6,通過(guò)實(shí)例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-05-05

最新評(píng)論