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

解決vue頁面刷新產(chǎn)生白屏的問題

 更新時(shí)間:2022年07月28日 11:02:59   作者:風(fēng)雨中的小菜鳥  
這篇文章主要介紹了解決vue頁面刷新產(chǎn)生白屏的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue頁面刷新產(chǎn)生白屏

app.vue

<template>
? <div id="app">
? ? <router-view v-if="isRouterAlive"></router-view>
? </div>
</template>
<script>
export default {
? provide() {
? ? return {
? ? ? reload: this.reload
? ? }
? },
? data() {
? ? return {
? ? ? isRouterAlive: true
? ? }
? },
? methods: {
? ? reload() {
? ? ? this.isRouterAlive = false
? ? ? this.$nextTick(function() {
? ? ? ? this.isRouterAlive = true
? ? ? })
? ? }
? }
}
</script>

將要引用的頁面 例如:home.vue

*注入*
inject: ['reload'],
*調(diào)用*
this.reload()

vue頁面白屏的原因及優(yōu)化

一、原因

單頁面應(yīng)用的 html 是靠 js 生成,因?yàn)槭灼列枰虞d很大的js文件(app.js 和vendor.js),所以當(dāng)網(wǎng)速差的時(shí)候會產(chǎn)生一定程度的白屏

二、解決辦法

1、路由懶加載,組件懶加載

路由懶加載

// 1、Vue異步組件技術(shù):
{
? path: '/home',
? name: 'Home',
? component: resolve => require(['../views/home.vue'], resolve)
}
// 2、es6提案的import()
{
? path: '/',
? name: 'home',
? component: () => import('../views/home.vue')
}
// 3、webpack提供的require.ensure()
{
? path: '/home',
? name: 'Home',
? component: r => require.ensure([],() => ?r(require('../views/home.vue')), 'home')
}

組件懶加載

components:{
? "dailyModal":()=>import("./dailyModal.vue")
},
components:{
? "dailyModal":resolve=>require(['./dailyModal.vue'],resolve)
},

2、CDN 資源優(yōu)化

CDN 的全稱是 Content Delivery Network,即內(nèi)容分發(fā)網(wǎng)絡(luò)。CDN 是構(gòu)建在網(wǎng)絡(luò)之上的內(nèi)容分發(fā)網(wǎng)絡(luò),依靠部署在各地的邊緣服務(wù)器,通過中心平臺的負(fù)載均衡、內(nèi)容分發(fā)、調(diào)度等功能模塊,使用戶就近獲取所需內(nèi)容,降低網(wǎng)絡(luò)擁塞,提高用戶訪問響應(yīng)速度和命中率。CDN 的關(guān)鍵技術(shù)主要有內(nèi)容存儲和分發(fā)技術(shù)。

隨著項(xiàng)目越做越大,依賴的第三方 npm 包越來越多,構(gòu)建之后的文件也會越來越大。再加上又是單頁應(yīng)用,這就會導(dǎo)致在網(wǎng)速較慢或者服務(wù)器帶寬有限的情況出現(xiàn)長時(shí)間的白屏。此時(shí)我們可以使用 CDN 的方法,優(yōu)化網(wǎng)絡(luò)加載速度。

將 vue、vue-router、vuex、axios 這些 vue 全家桶的資源,全部改為通過 CDN 鏈接獲取,在 index.html 里插入相應(yīng)鏈接。

<body>
? <div id="app"></div>
? ?? ?<script src="https://cdn.bootcss.com/vue/2.6.10/vue.min.js"></script>
? ?? ?<script src="https://cdn.bootcss.com/axios/0.19.0-beta.1/axios.min.js"></script>
? ?? ?<script src="https://cdn.bootcss.com/vuex/3.1.0/vuex.min.js"></script>
??? ?<script src="https://cdn.bootcss.com/vue-router/3.0.2/vue-router.min.js"></script>
??? ?<script src="https://cdn.bootcss.com/element-ui/2.6.1/index.js"></script>
</body>

在 vue.config.js 配置 externals 屬性

module.exports = {
?···
? ? externals: {
? ? ? 'vue': 'Vue',
? ? ? 'vuex': 'Vuex',
? ? ? 'vue-router': 'VueRouter',
? ? ? 'axios':'axios'
? ? }
?}

卸載相關(guān)依賴的 npm 包

npm uninstall ?vue vue-router vuex axios

3、gZip 加速優(yōu)化

所有現(xiàn)代瀏覽器都支持 gzip 壓縮,啟用 gzip 壓縮可大幅縮減傳輸資源大小,從而縮短資源下載時(shí)間,減少首次白屏?xí)r間,提升用戶體驗(yàn)。

gzip 對基于文本格式文件的壓縮效果最好(如:CSS、JavaScript 和 HTML),在壓縮較大文件時(shí)往往可實(shí)現(xiàn)高達(dá) 70-90% 的壓縮率,對已經(jīng)壓縮過的資源(如:圖片)進(jìn)行 gzip 壓縮處理,效果很不好。

const CompressionPlugin = require('compression-webpack-plugin')
configureWebpack: (config) => {
? if (process.env.NODE_ENV === 'production') {
? ? config.plugins.push(
? ? ? new CompressionPlugin({
? ? ? ? // gzip壓縮配置
? ? ? ? test: /\.js$|\.html$|\.css/, // 匹配文件名
? ? ? ? threshold: 10240, // 對超過10kb的數(shù)據(jù)進(jìn)行壓縮
? ? ? ? deleteOriginalAssets: false, // 是否刪除原文件
? ? ? })
? ? )
? }
}

4、vue.config.js中關(guān)閉productionSourceMap

productionSourceMap是用來報(bào)錯(cuò)時(shí)定位到代碼位置。

如果不想讓別人看到源碼可以設(shè)置為false,并且可以減少打包后包的體積,加密源碼。

productionSourceMap: false,

5、SSR,服務(wù)端渲染,在服務(wù)端事先拼裝好首頁所需的 html

6、首頁加 loading或 骨架屏(優(yōu)化體驗(yàn))

隨著 SPA 在前端界的逐漸流行,單頁面應(yīng)用不可避免地給首頁加載帶來壓力,此時(shí)良好的首頁用戶體驗(yàn)至關(guān)重要。很多 APP 采用了“骨架屏”的方式去展示未加載內(nèi)容,給予了用戶煥然一新的體驗(yàn)。

所謂的骨架屏,就是在頁面內(nèi)容未加載完成的時(shí)候,先使用一些圖形進(jìn)行占位,待內(nèi)容加載完成之后再把它替換掉。在這個(gè)過程中用戶會感知到內(nèi)容正在逐漸加載并即將呈現(xiàn),降低了“白屏”的不良體驗(yàn)。 

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • Vue?設(shè)置圖片不轉(zhuǎn)為base64的方式

    Vue?設(shè)置圖片不轉(zhuǎn)為base64的方式

    這篇文章主要介紹了Vue實(shí)現(xiàn)設(shè)置圖片不轉(zhuǎn)為base64的方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Vuejs從數(shù)組中刪除元素的示例代碼

    Vuejs從數(shù)組中刪除元素的示例代碼

    這篇文章主要介紹了Vuejs從數(shù)組中刪除元素的示例代碼,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • Vue2.0中三種常用傳值方式(父傳子、子傳父、非父子組件傳值)

    Vue2.0中三種常用傳值方式(父傳子、子傳父、非父子組件傳值)

    在Vue的框架開發(fā)的項(xiàng)目過程中,經(jīng)常會用到組件來管理不同的功能,有一些公共的組件會被提取出來。下面通過本文給大家介紹Vue開發(fā)中常用的三種傳值方式父傳子、子傳父、非父子組件傳值,需要的朋友參考下吧
    2018-08-08
  • vuex state及mapState的基礎(chǔ)用法詳解

    vuex state及mapState的基礎(chǔ)用法詳解

    這篇文章主要介紹了vuex state及mapState的基礎(chǔ)用法詳解,本文通過實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-04-04
  • vue axios基于常見業(yè)務(wù)場景的二次封裝的實(shí)現(xiàn)

    vue axios基于常見業(yè)務(wù)場景的二次封裝的實(shí)現(xiàn)

    這篇文章主要介紹了vue axios基于常見業(yè)務(wù)場景的二次封裝的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • uniapp和vue的區(qū)別詳解

    uniapp和vue的區(qū)別詳解

    這篇文章主要介紹了uniapp和vue的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • 詳解Vuex管理登錄狀態(tài)

    詳解Vuex管理登錄狀態(tài)

    這篇文章主要介紹了詳解Vuex管理登錄狀態(tài),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • vue項(xiàng)目下,如何用命令直接修復(fù)ESLint報(bào)錯(cuò)

    vue項(xiàng)目下,如何用命令直接修復(fù)ESLint報(bào)錯(cuò)

    這篇文章主要介紹了vue項(xiàng)目下,如何用命令直接修復(fù)ESLint報(bào)錯(cuò),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3模板引用的操作方式示例詳解

    Vue3模板引用的操作方式示例詳解

    這篇文章主要為大家介紹了Vue3模板引用的操作方式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • ElementUI動(dòng)態(tài)渲染el-table的實(shí)現(xiàn)過程

    ElementUI動(dòng)態(tài)渲染el-table的實(shí)現(xiàn)過程

    在前端開發(fā)中,表格是不可或缺的一部分,無論是數(shù)據(jù)展示、數(shù)據(jù)錄入,還是數(shù)據(jù)分析,表格都扮演著重要的角色,而在Vue.js生態(tài)系統(tǒng)中,ElementUI提供了一個(gè)強(qiáng)大且靈活的表格組件——el-table,本文將帶你深入了解如何使用ElementUI動(dòng)態(tài)渲染el-table,并詳細(xì)探討其原理及實(shí)現(xiàn)過程
    2024-08-08

最新評論