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

vue2首次加載屏幕閃爍問題

 更新時間:2025年01月16日 08:54:56   作者:程琬清君  
這篇文章詳細介紹了Vue.js項目的基本結(jié)構(gòu)和執(zhí)行流程,包括index.html、main.js、App.vue和路由配置的關(guān)系,特別強調(diào)了在index.html中設(shè)置BASE_URL和cdn的使用,以及在main.js中使用render函數(shù)來減少打包體積

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)文章

  • 讓ChatGPT解讀Vue3源碼過程解析

    讓ChatGPT解讀Vue3源碼過程解析

    這篇文章主要為大家介紹了讓ChatGPT解讀Vue3源碼過程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • vue圖片裁剪插件vue-cropper使用方法詳解

    vue圖片裁剪插件vue-cropper使用方法詳解

    這篇文章主要為大家詳細介紹了vue圖片裁剪插件vue-cropper使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • uniapp使用scroll-view下拉刷新無法取消的坑及解決

    uniapp使用scroll-view下拉刷新無法取消的坑及解決

    這篇文章主要介紹了uniapp使用scroll-view下拉刷新無法取消的坑及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • vue使用iframe嵌入網(wǎng)頁的示例代碼

    vue使用iframe嵌入網(wǎng)頁的示例代碼

    本篇文章主要介紹了vue使用iframe嵌入網(wǎng)頁的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 使用el-row及el-col頁面縮放時出現(xiàn)空行的問題及解決

    使用el-row及el-col頁面縮放時出現(xiàn)空行的問題及解決

    這篇文章主要介紹了使用el-row及el-col頁面縮放時出現(xiàn)空行的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue3如何自定義指令directive(如權(quán)限控制)

    Vue3如何自定義指令directive(如權(quán)限控制)

    本文詳細介紹了如何在Vue3項目中創(chuàng)建自定義指令directive1,首先,在src/directives/index.ts文件中引入自定義指令,然后,創(chuàng)建src/directives/permission.ts文件來定義具體指令邏輯,在main.ts文件中引入并注冊該指令,最后,在頁面中使用自定義指令
    2024-12-12
  • Vue3使用MD5加密實戰(zhàn)案例(清晰明了)

    Vue3使用MD5加密實戰(zhàn)案例(清晰明了)

    MD5是一種信息摘要算法(對稱加密),一種被廣泛使用的密碼散列函數(shù),可以產(chǎn)生出一個128位(16字節(jié))的散列值,用來確保信息傳輸完整一致性,這篇文章主要給大家介紹了關(guān)于Vue3使用MD5加密的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 淺聊一下Vue2中的functional組件

    淺聊一下Vue2中的functional組件

    最近聽到有人提到了Vue2的functional組件,大致上是說這個東西沒有生命周期,在渲染層面上,會減少很多的消耗,一番處理之后,首屏?xí)r間和內(nèi)存都能減少不少,所以本文小編就來和大家聊聊Vue2中的functional組件<BR>
    2023-08-08
  • vite中如何使用@?配置路徑別名

    vite中如何使用@?配置路徑別名

    這篇文章主要介紹了vite中如何使用@?配置路徑別名,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Element樹形控件el-tree實現(xiàn)一鍵全選、反選功能

    Element樹形控件el-tree實現(xiàn)一鍵全選、反選功能

    最近做的項目用到了全選全不選功能,于是就自己動手寫了一個,這篇文章主要給大家介紹了關(guān)于Element樹形控件el-tree實現(xiàn)一鍵全選、反選功能的相關(guān)資料,需要的朋友可以參考下
    2023-10-10

最新評論