解決nuxt頁(yè)面中mounted、created、watch執(zhí)行兩遍的問(wèn)題
前言:
在開(kāi)發(fā)中偶然檢查Network請(qǐng)求的時(shí)候發(fā)現(xiàn),在頁(yè)面中created鉤子函數(shù)中請(qǐng)求了一個(gè)接口,但是頁(yè)面這個(gè)頁(yè)面加載的時(shí)候,接口會(huì)連續(xù)請(qǐng)求兩邊,然后我就排查是否有其他地方調(diào)用了同樣的接口,檢查了好幾遍后發(fā)現(xiàn)并沒(méi)有,WTF,然后我在created中打印了一下,驚奇的發(fā)現(xiàn)。。。created會(huì)執(zhí)行兩次打印。。。
WTF、WTF、WTF,小朋友你是否有很多問(wèn)號(hào)???,然后試了下,不光created會(huì)執(zhí)行兩遍,mounted也行,就連watch里面監(jiān)聽(tīng)的也會(huì),握草(草是一種植物),此處省略我咔咔排查了一個(gè)小時(shí)各種刪除各種排查的步驟。。。
得出以下結(jié)論:
第一種:
頁(yè)面布局不合理,會(huì)導(dǎo)致執(zhí)行兩遍,比如行內(nèi)元素內(nèi)嵌套了塊級(jí)元素,然后塊級(jí)元素又使用了for,或者if,要想排查是否是這種情況,只能一點(diǎn)點(diǎn)刪除代碼,看看刪除了那一塊的代碼后不再執(zhí)行兩遍,然后從病根出排查修改。
第二種:
有使用v-if和v-else的結(jié)合也會(huì)執(zhí)行兩遍,這種的我測(cè)試了下,把v-if都改成v-show。。。就TM的好了。
第三種:
我在頁(yè)面中使用了swiper,發(fā)現(xiàn)。。。swiper的代碼也會(huì)觸發(fā)執(zhí)行兩遍,應(yīng)該是swiper的代碼觸發(fā)了規(guī)則,然后我在swiper組件使用一個(gè)div包裹了一下。。。發(fā)現(xiàn)好了,無(wú)語(yǔ),毫無(wú)規(guī)則可言
第四種:
還未發(fā)現(xiàn),,,歡迎評(píng)論增加
最后:
此文章使用了較多的**修飾詞,請(qǐng)?jiān)?。。。因?yàn)槟欠N你想象不到的問(wèn)題原因著實(shí)讓人。不說(shuō)了,求個(gè)贊吧?。?!
補(bǔ)充知識(shí):vue.js頁(yè)面加載執(zhí)行created,mounted先后順序
created頁(yè)面加載未渲染html之前執(zhí)行。
mounted渲染html后再執(zhí)行。
由于created在html模板生產(chǎn)之前所以無(wú)法對(duì)Dom進(jìn)行操作而mounted可以。
以上這篇解決nuxt頁(yè)面中mounted、created、watch執(zhí)行兩遍的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue 中 createElement 使用實(shí)例詳解
Vue 提供了createElement 來(lái)創(chuàng)建虛擬dom,方便我們來(lái)函數(shù)化的方式來(lái)定義復(fù)雜的組件結(jié)構(gòu),這篇文章主要介紹了Vue 中 createElement 使用詳解,需要的朋友可以參考下2022-10-10
vue使用腳手架vue-cli創(chuàng)建并引入自定義組件
這篇文章介紹了vue使用腳手架vue-cli創(chuàng)建并引入自定義組件的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
vue工程師必會(huì)封裝的埋點(diǎn)指令思路知識(shí)總結(jié)
這篇文章主要給大家總結(jié)介紹了關(guān)于vue工程師必會(huì)封裝的埋點(diǎn)指令思路知識(shí),文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-12-12
vue中style設(shè)置scoped后部分樣式不生效的解決
這篇文章主要介紹了vue中style設(shè)置scoped后部分樣式不生效的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09
vue實(shí)現(xiàn)導(dǎo)航菜單和編輯文本的示例代碼
這篇文章主要介紹了vue實(shí)現(xiàn)導(dǎo)航菜單和編輯文本功能的方法,文中示例代碼非常詳細(xì),幫助大家更好的參考和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07
vue新手入門出現(xiàn)function () { [native code]&nbs
這篇文章主要介紹了vue新手入門出現(xiàn)function () { [native code] }錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04

