Vue SPA 首屏優(yōu)化方案
常規(guī) vue 項(xiàng)目打包后訪問(wèn),返回一個(gè)只包含 div 的 html,其他內(nèi)容塊都是通過(guò) js 動(dòng)態(tài)生成的。

存在兩個(gè)比較大的問(wèn)題:
不利于 seo 首屏加載頁(yè)慢,用戶體驗(yàn)不好本文是自己根據(jù)項(xiàng)目經(jīng)驗(yàn)總結(jié)的方案,如有不足,歡迎指出~
優(yōu)化SSRSSR(Server-Side Rendering) 即服務(wù)端渲染,把 vue 組件在服務(wù)器端渲染為組裝好的 HTML 字符串,然后將它們直接發(fā)送到瀏覽器,最后需要將這些靜態(tài)標(biāo)記混合在客戶端上完全可交互的應(yīng)用程序。使用 ssr 重新部署構(gòu)建項(xiàng)目后:

可以看到返回的內(nèi)容就已經(jīng)包含了首屏內(nèi)容的 html 代碼塊,perfect!~.~
極速傳送門(mén): 基于vue-cli4.0+Typescript+SSR的小Demo
按需引入使用 es6 module 進(jìn)行按需引入
1. 路由文件中按需引入組件# router.index.tsexport 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)庫(kù)按需引入模塊,而不是全部
如 element-ui 庫(kù)中,我只想用 button 組件 :
import { button} from ’element-ui’;請(qǐng)求優(yōu)化1. css、js 放置順序
css 文件放 header 中,js 文件放 body前,不過(guò) vue 已經(jīng)幫我們處理好了~
2. 使用字體圖標(biāo),icon 資源使用雪碧圖我們知道 http 建立一次連接需要 3 次握手,太多的請(qǐng)求會(huì)影響加載速度
對(duì)不必要的靜態(tài)資源我們應(yīng)該盡量減少,比如頁(yè)面中的 icon 圖標(biāo),如下騰訊官網(wǎng)的一個(gè)圖片:

直接引入一張完成的圖片,根據(jù) background-position 來(lái)設(shè)置圖片的位置
使用CDN靜態(tài)資源都上傳到 CDN,提高訪問(wèn)速度
不使用 CDN:
可以看到使用 CDN后,會(huì)對(duì)靜態(tài)文件進(jìn)行 GZIP 壓縮, 下載度度極大的提高

拆分入口 chunk 文件,分離出一些靜態(tài)的庫(kù),既可以加速打包,也可以優(yōu)化加載。
如下,分離了一些靜態(tài)庫(kù):vuejs、axios、vuex等,可以看到瀏覽器將開(kāi)啟多個(gè)下載線程進(jìn)行下載。若沒(méi)有分離這些靜態(tài)庫(kù),入口 chunk 將十分巨大,加載速度可想而知~.~

分離一個(gè) element-ui 庫(kù),dev 環(huán)境我們不用管,prod 環(huán)境下我們才分離,只需要在 vue 打包配置中移除該庫(kù)即可:
# vue.config.jsconfigureWebpack: { externals: process.env.NODE_ENV === ’production’ ? { ’element-ui’: ’element-ui’, } : undefined,},# index.html 手動(dòng)引入靜態(tài)資源<script src='http://www.leifengta.com.cn/js/element-ui/element-ui.2.11.1.js'></script>
以上就是Vue SPA 首屏優(yōu)化方案的詳細(xì)內(nèi)容,更多關(guān)于Vue SPA 首屏優(yōu)化的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 詳解Android studio 動(dòng)態(tài)fragment的用法2. 什么是python的自省3. 解決Android studio xml界面無(wú)法預(yù)覽問(wèn)題4. Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁(yè)效果(實(shí)例代碼)5. 圖文詳解vue中proto文件的函數(shù)調(diào)用6. php模擬實(shí)現(xiàn)斗地主發(fā)牌7. Springboot Druid 自定義加密數(shù)據(jù)庫(kù)密碼的幾種方案8. Vue封裝一個(gè)TodoList的案例與瀏覽器本地緩存的應(yīng)用實(shí)現(xiàn)9. vue 使用localstorage實(shí)現(xiàn)面包屑的操作10. Vuex localStorage的具體使用

網(wǎng)公網(wǎng)安備