欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue SPA 首屏優(yōu)化方案

 更新時間:2021年02月26日 10:40:29   作者:小豪看世界  
這篇文章主要介紹了Vue SPA 首屏優(yōu)化方案的的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用vue,感興趣的朋友可以了解下

前言

常規(guī) vue 項目打包后訪問,返回一個只包含 div 的 html,其他內(nèi)容塊都是通過 js 動態(tài)生成的。

存在兩個比較大的問題:

  • 不利于 seo
  • 首屏加載頁慢,用戶體驗不好

本文是自己根據(jù)項目經(jīng)驗總結(jié)的方案,如有不足,歡迎指出~

優(yōu)化

SSR

SSR(Server-Side Rendering) 即服務(wù)端渲染,把 vue 組件在服務(wù)器端渲染為組裝好的 HTML 字符串,然后將它們直接發(fā)送到瀏覽器,最后需要將這些靜態(tài)標(biāo)記混合在客戶端上完全可交互的應(yīng)用程序。
使用 ssr 重新部署構(gòu)建項目后:

可以看到返回的內(nèi)容就已經(jīng)包含了首屏內(nèi)容的 html 代碼塊,perfect!~.~

極速傳送門: 基于vue-cli4.0+Typescript+SSR的小Demo

按需引入

使用 es6 module 進(jìn)行按需引入

1. 路由文件中按需引入組件

# router.index.ts
export function createRouter() {
 return new Router({
 mode: 'history',
 routes: [
  {
  path: '/',
  name: 'Home',
  component: () => import(/* webpackChunkName: "Home" */ './views/Home.vue'),
  },
  {
  path: '/about',
  name: 'About',
  component: () => import(/* webpackChunkName: "about" */ './views/About.vue'),
  },
 ],
 });
}

2. 靜態(tài)庫按需引入模塊,而不是全部

如 element-ui 庫中,我只想用 button 組件 :

import {
 button
} from 'element-ui';

請求優(yōu)化

1. css、js 放置順序

css 文件放 header 中,js 文件放 body前,不過 vue 已經(jīng)幫我們處理好了~

2. 使用字體圖標(biāo),icon 資源使用雪碧圖

我們知道 http 建立一次連接需要 3 次握手,太多的請求會影響加載速度

對不必要的靜態(tài)資源我們應(yīng)該盡量減少,比如頁面中的 icon 圖標(biāo),如下騰訊官網(wǎng)的一個圖片:

直接引入一張完成的圖片,根據(jù) background-position 來設(shè)置圖片的位置

使用CDN

靜態(tài)資源都上傳到 CDN,提高訪問速度

不使用 CDN:

使用 CDN:

可以看到使用 CDN后,會對靜態(tài)文件進(jìn)行 GZIP 壓縮, 下載度度極大的提高

入口 chunk 優(yōu)化

拆分入口 chunk 文件,分離出一些靜態(tài)的庫,既可以加速打包,也可以優(yōu)化加載。

如下,分離了一些靜態(tài)庫:vuejs、axios、vuex等,可以看到瀏覽器將開啟多個下載線程進(jìn)行下載。若沒有分離這些靜態(tài)庫,入口 chunk 將十分巨大,加載速度可想而知~.~

分離一個 element-ui 庫,dev 環(huán)境我們不用管,prod 環(huán)境下我們才分離,只需要在 vue 打包配置中移除該庫即可:

# vue.config.js
configureWebpack: {
 externals:
 process.env.NODE_ENV === 'production'
  ? {
  'element-ui': 'element-ui',
  }
  : undefined,
},

# index.html 手動引入靜態(tài)資源
<script src="/js/element-ui/element-ui.2.11.1.js"></script>

以上就是Vue SPA 首屏優(yōu)化方案的詳細(xì)內(nèi)容,更多關(guān)于Vue SPA 首屏優(yōu)化的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Electron-store本地存儲功能用法詳解

    Electron-store本地存儲功能用法詳解

    這篇文章主要為大家介紹了Electron-store本地存儲功能的用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 解決vue3?defineProps?引入定義的接口報錯

    解決vue3?defineProps?引入定義的接口報錯

    這篇文章主要為大家介紹了解決vue3?defineProps?引入定義的接口報錯詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • vue視頻播放暫停代碼

    vue視頻播放暫停代碼

    今天小編就為大家分享一篇vue視頻播放暫停代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 詳解VUE前端按鈕權(quán)限控制

    詳解VUE前端按鈕權(quán)限控制

    這篇文章主要介紹了VUE前端按鈕權(quán)限控制,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue中多路由表頭吸頂實現(xiàn)的幾種布局方式

    vue中多路由表頭吸頂實現(xiàn)的幾種布局方式

    這篇文章主要介紹了vue項目多路由表頭吸頂實現(xiàn)的幾種布局方式,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • vue通過vue-lazyload實現(xiàn)圖片懶加載的代碼詳解

    vue通過vue-lazyload實現(xiàn)圖片懶加載的代碼詳解

    這篇文章主要給大家介紹了vue通過vue-lazyload實現(xiàn)圖片懶加載,文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • vue中的主動觸發(fā)點擊事件

    vue中的主動觸發(fā)點擊事件

    這篇文章主要介紹了vue中的主動觸發(fā)點擊事件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue3+echarts+折線投影(陰影)效果的實現(xiàn)

    vue3+echarts+折線投影(陰影)效果的實現(xiàn)

    這篇文章主要介紹了vue3+echarts+折線投影(陰影)效果的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 使用mint-ui開發(fā)項目的一些心得(分享)

    使用mint-ui開發(fā)項目的一些心得(分享)

    下面小編就為大家?guī)硪黄褂胢int-ui開發(fā)項目的一些心得(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Vue實現(xiàn)簡易記事本功能

    Vue實現(xiàn)簡易記事本功能

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)簡易記事本功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11

最新評論