vue2首次加載屏幕閃爍問題
vue2首次加載屏幕閃爍
先看我的bug動圖:
我想要的動圖:
可能圖片不明顯 反正就是只要這個正在加載資源這個頁面
1.了解vue項目執(zhí)行流程
vue項目中影響組件渲染和掛載有這幾個文件:index.html、main.js、App.vue、路由配置,那么它們之間的關(guān)系是如何呢?
答:
- 1.index.html是項目入口
- 2.main.js是入口文件(值得關(guān)注的是main.js的render函數(shù),下面會詳細的講)
- 3.App.vue根組件
- 4.路由配置(作用是:將路由名字和組件映射并渲染到App.vue)
執(zhí)行順序:index.html、main.js、App.vue、路由配置index.js、具體vue組件
index.html
①想要項目打包體積小,我們經(jīng)常將第三方庫的cdn寫在index.html,比如(需要先將cdn下載到項目里):
<head> <link rel="stylesheet" href="<%= BASE_URL %>cdn/element-ui/2.15.12/theme-chalk/index.css" rel="external nofollow" > </head>
有人可能會問BASE_URL是什么?答:這個BASE_URL是根據(jù)vue.config.js的publicPath去設(shè)置的路徑,這個路徑?jīng)Q定了我們的前端項目打包后獲取靜態(tài)資源的默認的根路徑。
- ②body標(biāo)簽里的<noscript></noscript>里寫如果沒有js支持時,將寫的的代碼。
- ③重點?。ody標(biāo)簽里的<div id="app"></div>里面寫的是:當(dāng)vue實例還沒有完成掛載時,vue項目將顯示什么內(nèi)容。
列取一段代碼:
<body> <div id="app"> <div class="avue-home"> <div class="avue-home__main"> <img class="avue-home__loading" src="<%= BASE_URL %>svg/loading-spin.svg" alt="loading"> <div class="avue-home__title"> 正在加載資源 </div> <div class="avue-home__sub-title d"> 初次加載資源可能需要較多時間 請耐心等待 </div> </div> </div> </div> </body>
- ④那跟<div id="app"><div>同級的標(biāo)簽還會顯示嗎?答:會!因為在vue實例還沒有掛載時,會運行index.html整個文件。
- ⑤js也就是<script>標(biāo)簽最好寫在</body>之上,比如:
簡寫代碼:
<body> <div id="app"> </div> <script src="<%= BASE_URL %>cdn/xlsx/xlsx.full.min.js"></script> </body>
main.js
- ①我們最應(yīng)該也重點注意到這段代碼:
var vue = new Vue({ router, render: h => h(App), beforeCreate() { } // 一般不寫生命周期,這里我只是列出來告訴你們--->這里是vue實例,所以什么生命周期,data統(tǒng)統(tǒng)可以寫 }).$mount('#app')
1.render是重點:請務(wù)必注意它必須要有返回值。為什么是render?
答:請看這2句代碼
import Vue from 'vue'; import App from './App';
(1)vue.js才是完整版的vue,包含了:核心功能 + 模板解析器,它在
(2)vue.runtime.xxx.js是運行版的vue,只包含了:核心功能,沒有模板解析器。
完整的vue你可以看node_modules下的vue文件,如下圖
因為我們項目里用的是殘缺的vue.js,是一個不會解析template標(biāo)簽的vue.js,引用render是為了減少打包的文件大小、使打包文件不會出現(xiàn)沒有用處的模板解析器。
2.項目中出現(xiàn)白屏閃爍的原因以及解決方式
原因:可以根據(jù)上面的vue項目執(zhí)行的流程可得,vue實例中的組件的模板內(nèi)容(即app.vue)取代了index.html的<div id="app"></div>里的內(nèi)容,在這個瞬間出現(xiàn)的白屏閃爍。
我看了網(wǎng)上很多人說v-cloak但我試了沒用,以下是我的處理方式,效果是達到了,可能還不夠很好,如果有大佬有更好的辦法請在此條文章下評論大家一起探討。
1.我原本的代碼:
index.html <div id="app"> <div class="avue-home"> <div class="avue-home__main"> <img class="avue-home__loading" src="<%= BASE_URL %>svg/loading-spin.svg" alt="loading"> <div class="avue-home__title"> 正在加載資源 </div> <div class="avue-home__sub-title d"> 初次加載資源可能需要較多時間 請耐心等待 </div> </div> </div> </div>
2.我修改后的代碼
index.html文件里(你沒看錯,我將我要展示的內(nèi)容寫到了<div id="app">同級的地方):
<div id="app"> </div> <div class="avue-home"> <div class="avue-home__main"> <img class="avue-home__loading" src="<%= BASE_URL %>svg/loading-spin.svg" alt="loading"> <div class="avue-home__title"> 正在加載資源 </div> <div class="avue-home__sub-title d"> 初次加載資源可能需要較多時間 請耐心等待 </div> </div> </div>
并在index.html文件里寫上avue-home的樣式,我的樣式是(供參考):
.avue-home { background-color: #303133; height: 100vh; width: 100%; display: flex; flex-direction: column; position: fixed; top: 0; left: 0; z-index: 999; }
接下來是重點了:
我們都知道最后是app.vue的代碼替換了<div id='app'>,所以在app.vue文件里寫:
- app.vue
mounted () { // 當(dāng)app.vue掛載完畢時,讓瀏覽器延遲1s自動刪除class為.avue-home的這個節(jié)點(有點繞,但可以好好想想) const avueHome = document.querySelector('.avue-home') // 獲取到這個class的節(jié)點 setTimeout(() => { avueHome.parentNode.removeChild(avueHome) // 該節(jié)點的父級去刪除這個class }, 1000) },
希望大家細品這兩句代碼。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
uniapp使用scroll-view下拉刷新無法取消的坑及解決
這篇文章主要介紹了uniapp使用scroll-view下拉刷新無法取消的坑及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05使用el-row及el-col頁面縮放時出現(xiàn)空行的問題及解決
這篇文章主要介紹了使用el-row及el-col頁面縮放時出現(xiàn)空行的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03Vue3如何自定義指令directive(如權(quán)限控制)
本文詳細介紹了如何在Vue3項目中創(chuàng)建自定義指令directive1,首先,在src/directives/index.ts文件中引入自定義指令,然后,創(chuàng)建src/directives/permission.ts文件來定義具體指令邏輯,在main.ts文件中引入并注冊該指令,最后,在頁面中使用自定義指令2024-12-12Element樹形控件el-tree實現(xiàn)一鍵全選、反選功能
最近做的項目用到了全選全不選功能,于是就自己動手寫了一個,這篇文章主要給大家介紹了關(guān)于Element樹形控件el-tree實現(xiàn)一鍵全選、反選功能的相關(guān)資料,需要的朋友可以參考下2023-10-10