vue mounted 調(diào)用兩次的完美解決辦法
在開發(fā)中發(fā)現(xiàn)其中一個頁面moutned調(diào)用了兩次,而其他頁面正常,表示很懵逼,然后查找原因,終于找到了,其實歸根到底是要知道m(xù)ounted的調(diào)用機制問題;
情況:在這個頁面中出現(xiàn)了mounted 加載了兩次的情況;
方法:排除法
首先把 this.$store.commit()
方法注釋掉,發(fā)現(xiàn)就好了,只加載一次
初步判斷是commit 方法導(dǎo)致的
二 驗證判斷是否正確,不使用commit 方法,該用直接改變變量狀態(tài)的方法,發(fā)現(xiàn)又加載了兩次;
再次判斷,不是由于commit引起的
三 猜想commit到底實現(xiàn)了什么邏輯,然后找到了v-if
v-if會重新渲染頁面,而mounted 又是在重新渲染完成之后調(diào)用的,所以猜想是v-if導(dǎo)致的
然后換成v-show 發(fā)現(xiàn)完美解決問題;
v-show 不會重新加載頁面,僅僅是顯示隱藏而已;
從網(wǎng)上找來的生命周期圖,各位網(wǎng)友可以了解一下,希望給你帶來一些啟發(fā);
PS:下面看下mounted函數(shù)調(diào)用技巧
為了確保dom成功渲染,利用setTimeout()
mounted() { setTimeout(() => { this._setSliderWidth() this._initDots() this._initSlider() if (this.autoPlay) { this._play() } }, 20)}
瀏覽器的刷新通常是17毫秒一次,所以這里用了20毫秒
總結(jié)
以上所述是小編給大家介紹的vue mounted 調(diào)用兩次的完美解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
vue2 中使用 render 函數(shù)編寫組件的方式
vue提供了聲明式編寫UI的方式,即vue提供了對DOM進行描述的方式,有兩種描述DOM的方式即模板和render 函數(shù),本文通過示例代碼介紹vue2 中使用 render 函數(shù)編寫組件的方式,感興趣的朋友跟隨小編一起看看吧2024-06-06vue+elementUI動態(tài)增加表單項并添加驗證的代碼詳解
這篇文章主要介紹了vue+elementUI動態(tài)增加表單項并添加驗證的代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12Vue結(jié)合leaflet實現(xiàn)克里金插值
本文主要介紹了Vue結(jié)合leaflet實現(xiàn)克里金插值,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06