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

淺談VUE單頁應(yīng)用首屏加載速度優(yōu)化方案

 更新時(shí)間:2018年08月28日 10:44:48   作者:停停兒  
這篇文章主要介紹了淺談VUE單頁應(yīng)用首屏加載速度優(yōu)化方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

單頁應(yīng)用會(huì)隨著項(xiàng)目越大,導(dǎo)致首屏加載速度很慢!??!以下給出在下知道的幾種優(yōu)化方案

  • 使用CDN資源,減小服務(wù)器帶寬壓力
  • 路由懶加載
  • 將一些靜態(tài)js css放到其他地方(如OSS),減小服務(wù)器壓力
  • 按需加載三方資源,如iview,建議按需引入iview中的組件
  • 使用nginx開啟gzip減小網(wǎng)絡(luò)傳輸?shù)牧髁看笮?/li>
  • webpack開啟gzip壓縮
  • 若首屏為登錄頁,可以做成多入口,登錄頁單獨(dú)分離為一個(gè)入口

使用CDN資源,減小服務(wù)器帶寬壓力

在index.html中引入cdn資源

...
 <body>
  <div id="app">
  </div>
  <!-- built files will be auto injected -->
  <script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>
  <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
  <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script>
  <script src="https://cdn.bootcss.com/vue-resource/1.5.1/vue-resource.min.js"></script>
 </body>
 ...

修改 build/webpack.base.conf.js

module.exports = {
 context: path.resolve(__dirname, '../'),
 entry: {
  app: './src/main.js'
 },
 externals:{
  'vue': 'Vue',
  'vue-router': 'VueRouter',
  'vuex':'Vuex',
  'vue-resource': 'VueResource'
 },
 ...
}

修改src/main.js src/router/index.js 注釋掉import引入的vue,vue-resource

// import Vue from 'vue'
// import VueResource from 'vue-resource'
// Vue.use(VueResource)

路由懶加載

const workCircle = r => require.ensure([], () => r(require('@/module/work-circle/Index')), 'workCircle')
const workCircleList = r => require.ensure([], () => r(require('@/module/work-circle/page/List')), 'workCircleList')

將一些靜態(tài)js css放到其他地方(如OSS),減小服務(wù)器壓力

注意這里的js文件,需要將結(jié)果拋出,然后在需要用到該js的組件中import引入

按需加載三方資源,如iview,建議按需引入iview中的組件

按需引用請(qǐng)查看iview官方文檔iview

使用nginx開啟gzip減小網(wǎng)絡(luò)傳輸?shù)牧髁看笮?/strong>

配置nginx,可以參考Nginx開啟Gzip壓縮大幅提高頁面加載速度

webpack開啟gzip壓縮

這里需要配合Nginx服務(wù)器,Nginx開啟gzip

config/index.js中

module.exports = {
 build: {
  ...
  // Gzip off by default as many popular static hosts such as
  // Surge or Netlify already gzip all static assets for you.
  // Before setting to `true`, make sure to:
  // npm install --save-dev compression-webpack-plugin
  productionGzip: true, // 就是這里開啟gzip,vue-cli搭建項(xiàng)目,這里默認(rèn)為false
  productionGzipExtensions: ['js', 'css'],

  // Run the build command with an extra argument to
  // View the bundle analyzer report after build finishes:
  // `npm run build --report`
  // Set to `true` or `false` to always turn it on or off
  bundleAnalyzerReport: process.env.npm_config_report
 }
}

build/webpack.prod.conf.js中

使用vue-cli構(gòu)建項(xiàng)目時(shí),默認(rèn)會(huì)有這段代碼

if (config.build.productionGzip) {
 const CompressionWebpackPlugin = require('compression-webpack-plugin')
 webpackConfig.plugins.push(
  new CompressionWebpackPlugin({
   asset: '[path].gz[query]',
   algorithm: 'gzip',
   test: new RegExp(
    '\\.(' +
    config.build.productionGzipExtensions.join('|') +
    ')$'
   ),
   threshold: 10240,
   minRatio: 0.8
  })
 )
}

若首屏為登錄頁,可以做成多入口,登錄頁單獨(dú)分離為一個(gè)入口

修改webpack配置

在原先只有一個(gè)入口叫app的基礎(chǔ)上,再加一個(gè)叫l(wèi)ogin的入口,指向另一個(gè)入口js文件;

既然是兩個(gè)頁面,那么原先只有一個(gè)的HtmlWebpackPlugin也需要再添加一個(gè),并且filename和template改成登錄頁的;

HtmlWebpackPlugin默認(rèn)會(huì)把所有資源放進(jìn)html,為了去掉不需要的資源,需要在HtmlWebpackPlugin選項(xiàng)里分別添加excludeChunks: ['login']和excludeChunks: ['app'];

原先的某些CommonsChunkPlugin會(huì)導(dǎo)致報(bào)錯(cuò),刪掉只剩下一個(gè)manifest的CommonsChunkPlugin就好。

添加登錄相關(guān)文件

添加之前配好的login入口文件,與app類似,但是去掉登錄頁不需要的東西,如用不到的組件和樣式等;

添加login入口專用的router配置文件,去掉其他路由,只留下登錄頁一個(gè)就好:

只留登錄路由

添加登錄頁的html模板,也是去掉登錄里用不到的資源。

修改其他細(xì)節(jié)

登錄完不是用vue-router的push方法,而是改成直接修改location.href跳到另一個(gè)頁面;

去除原來app路由中的login;

登錄頁中可以使用隱藏的iframe等方式預(yù)加載app頁面中的數(shù)據(jù)(猜想)。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于vue中api統(tǒng)一管理的那些事

    關(guān)于vue中api統(tǒng)一管理的那些事

    最近在學(xué)習(xí)Vue教程,下面這篇文章主要給大家介紹了關(guān)于vue中api統(tǒng)一管理的那些事,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-04-04
  • Vue?插件及瀏覽器本地存儲(chǔ)

    Vue?插件及瀏覽器本地存儲(chǔ)

    這篇文章主要介紹了Vue?插件及瀏覽器本地存儲(chǔ),插件通常用來為Vue添加全局功能,包含install方法的一個(gè)對(duì)象。更多相關(guān)介紹,需要的小伙伴可以參考下面文章內(nèi)容
    2022-05-05
  • vue3封裝簡易的vue-echarts問題

    vue3封裝簡易的vue-echarts問題

    這篇文章主要介紹了vue3封裝簡易的vue-echarts問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vant 解決tab切換插件標(biāo)題樣式自定義的問題

    vant 解決tab切換插件標(biāo)題樣式自定義的問題

    這篇文章主要介紹了vant 解決tab切換插件標(biāo)題樣式自定義的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue3監(jiān)聽路由的變化代碼示例

    vue3監(jiān)聽路由的變化代碼示例

    在vue項(xiàng)目中假使我們?cè)谕粋€(gè)路由下,只是改變路由后面的參數(shù)值,期望達(dá)到數(shù)據(jù)的更新,這篇文章主要給大家介紹了關(guān)于vue3監(jiān)聽路由的變化的相關(guān)資料,需要的朋友可以參考下
    2023-09-09
  • vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果

    vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果

    這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue?的全選組件封裝你知道多少

    vue?的全選組件封裝你知道多少

    這篇文章主要為大家詳細(xì)介紹了vue的全選組件封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • Vue3+Ant?design?實(shí)現(xiàn)Select下拉框一鍵全選/清空功能

    Vue3+Ant?design?實(shí)現(xiàn)Select下拉框一鍵全選/清空功能

    在做后臺(tái)管理系統(tǒng)項(xiàng)目的時(shí)候,產(chǎn)品增加了一個(gè)在Select選擇器中添加一鍵全選和清空的功能,他又不讓在外部增加按鈕,其實(shí)如果說在外部增加按鈕實(shí)現(xiàn)全選或者清空的話,功能比較簡單的,下面給大家分享Vue3+Ant?design?實(shí)現(xiàn)Select下拉框一鍵全選/清空功能,需要的朋友可以參考下
    2024-05-05
  • vue style屬性設(shè)置背景圖片的相對(duì)路徑無效的解決

    vue style屬性設(shè)置背景圖片的相對(duì)路徑無效的解決

    這篇文章主要介紹了vue style屬性設(shè)置背景圖片的相對(duì)路徑無效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 解決vue3項(xiàng)目打包后部署后某些靜態(tài)資源圖片不加載問題

    解決vue3項(xiàng)目打包后部署后某些靜態(tài)資源圖片不加載問題

    這篇文章主要給大家介紹了如何解決vue3項(xiàng)目打包后部署后某些靜態(tài)資源圖片不加載問題,文中通過圖文結(jié)合的方式講解的非常詳細(xì),有需要的朋友可以參考下
    2024-05-05

最新評(píng)論