1. 程式人生 > 程式設計 >Vue SPA 首屏優化方案

Vue SPA 首屏優化方案

前言

常規 vue 專案打包後訪問,返回一個只包含 div 的 html,其他內容塊都是通過 js 動態生成的。

Vue SPA 首屏優化方案

存在兩個比較大的問題:

  • 不利於 seo
  • 首屏載入頁慢http://www.cppcns.com,使用者體驗不好

本文是自己根據專案經驗總結的方案,如有不足,歡迎指出~

優化

SSR

SSR(Server-Side Rendering) 即服務端渲染,把 vue 元件在伺服器端渲染為組裝好www.cppcns.com的 HTML 字串,然後將它們直接傳送到瀏覽器,最後需要將這些靜態標記混合在客戶端上完全可互動的應用程式。
使用 ssr 重新部署構建專案後:

Vue SPA 首屏優化方案

可以看到返回的內容就已經包含了首屏內容的 html 程式碼塊,perfect!~.~

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

按需引入

使用 es6 module 進行按需引入

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. 靜態庫按需引入模組,而不是全部

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

import {
 bu程式設計客棧tton
} from 'element-ui';

請求優化

1. css、js 放置順序

css 檔案放 header 中,js 檔案放 body前,不過 vue 已經幫我們處理好了~

2. 使用字型圖示,icon 資源使用雪碧圖

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

對不必要的靜態資源我們應該儘量減少,比如頁面中的 icon 圖示,如下騰訊官網的一個圖片:

Vue SPA 首屏優化方案

直接引入一張完成的圖片,根據 background-position 來設定圖片的位置

使用CDN

靜態資源都上傳到 CDN,提高訪問速度

不使用 CDN:

Vue SPA 首屏優化方案

使用 CDN:

可以看到使用 CDN後,會對靜態檔案進行 GZIP 壓縮, 下載度度極大的提高

Vue SPA 首屏優化方案

入口 chunk 優化

拆分入口 chunk 檔案,分離出一些靜態的庫,既可以加速打包,也可以優化載入。

如下,分離了一些靜態庫:vuejs、axios、vuex等,可以看到瀏覽器將開啟多個下載執行緒進行下載。若沒有分離這些靜態庫,入口 chunk 將十分巨大,載入速度可想而知~.~

Vue SPA 首屏優化方案

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

# vue.config.js
configureWebpack: {
 externals:
 process.env.NODE_ENV === 'production'
  ? {
  'element-ui': 'element-ui',}
  : undefined,程式設計客棧# index.html 手動引入靜態資源
<script src="/js/element-ui/element-ui.2.11.1.js"></script>

以上就是Vue SPA 首屏優化方案的詳細內容,更多關於Vue SPA 首屏優化的資料請關注我們其它相關文章!