1. 程式人生 > 程式設計 >解決nuxt頁面中mounted、created、watch執行兩遍的問題

解決nuxt頁面中mounted、created、watch執行兩遍的問題

前言:

在開發中偶然檢查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可以。

以上這篇解決nuxt頁面中mounted、created、watch執行兩遍的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。