您好,登錄后才能下訂單哦!
mounted、created和watch在nuxt頁面中執行兩遍怎么解決?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
前言:
在開發中偶然檢查Network請求的時候發現,在頁面中created鉤子函數中請求了一個接口,但是頁面這個頁面加載的時候,接口會連續請求兩邊,然后我就排查是否有其他地方調用了同樣的接口,檢查了好幾遍后發現并沒有,WTF,然后我在created中打印了一下,驚奇的發現。。。created會執行兩次打印。。。
WTF、WTF、WTF,小朋友你是否有很多問號???,然后試了下,不光created會執行兩遍,mounted也行,就連watch里面監聽的也會,握草(草是一種植物),此處省略我咔咔排查了一個小時各種刪除各種排查的步驟。。。
得出以下結論:
第一種:
頁面布局不合理,會導致執行兩遍,比如行內元素內嵌套了塊級元素,然后塊級元素又使用了for,或者if,要想排查是否是這種情況,只能一點點刪除代碼,看看刪除了那一塊的代碼后不再執行兩遍,然后從病根出排查修改。
第二種:
有使用v-if和v-else的結合也會執行兩遍,這種的我測試了下,把v-if都改成v-show。。。就TM的好了。
第三種:
我在頁面中使用了swiper,發現。。。swiper的代碼也會觸發執行兩遍,應該是swiper的代碼觸發了規則,然后我在swiper組件使用一個div包裹了一下。。。發現好了,無語,毫無規則可言
第四種:
還未發現,,,歡迎評論增加
最后:
此文章使用了較多的**修飾詞,請原諒。。。因為那種你想象不到的問題原因著實讓人。不說了,求個贊吧!!!
補充知識:vue.js頁面加載執行created,mounted先后順序
created頁面加載未渲染html之前執行。
mounted渲染html后再執行。
由于created在html模板生產之前所以無法對Dom進行操作而mounted可以。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。