本文小編為大家詳細介紹“Vuex無法觀察到值變化怎么解決”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“Vuex無法觀察到值變化怎么解決”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
在喀什等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、成都做網(wǎng)站 網(wǎng)站設(shè)計制作定制設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,成都營銷網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站制作,喀什網(wǎng)站建設(shè)費用合理。
在跨越主路由視圖時,由于Vuex的狀態(tài)值一直存儲在內(nèi)存中,所以在組件視圖重新載入時,可能會出現(xiàn)組件無法檢測到狀態(tài)值的變化,從而導致業(yè)務(wù)邏輯出現(xiàn)錯誤。
假定通用頭部組件有一個全局任務(wù)狀態(tài)值,其他的組件都要根據(jù)此任務(wù)值進行更新,更可能出現(xiàn)的情況是,任務(wù)狀態(tài)值是異步加載完成的,于是需要如此編寫業(yè)務(wù)邏輯:
computed : { task () { return this.$store.state.task } }, watch : { task : { deep: true, handler (val) { // 由于是異步載入,所以只能在狀態(tài)值的變化時執(zhí)行渲染操作 // 絕不可在mounted中執(zhí)行render方法 this.render(val) } } }
但是,由于上面的原因,第一次載入視圖時,因為Vuex的狀態(tài)值還沒有存儲在內(nèi)存中,所以渲染正常。發(fā)生了視圖切換后,雖然也重新載入了任務(wù)狀態(tài)值,但由于task并沒有發(fā)生變化,所以render方法不會被調(diào)用,于是組件無法完成渲染過程。
解決的辦法很簡單,強行觸發(fā)task值發(fā)生改變,方法是定義一個時間戳,如果覺得在時間戳的粒度仍然太粗,還可以組合使用隨機數(shù),如下:
watch: { taskId : { handler (val) { // 從v-model獲取到的新值 let taskId = this.taskId // 提交新值變化 this.$store.commit(TASK_ID, { id : taskId, // 添加時間戳 time : Date.now().valueOf(), // 添加隨機數(shù) random : Math.random() }) } } }
經(jīng)過上面的處理,只要發(fā)生taskId的賦值現(xiàn)象,那么一定會觸發(fā)Vuex的狀態(tài)變化,所以每次組件載入時或taskId的值發(fā)生變化時,render方法就一定會被執(zhí)行。
讀到這里,這篇“Vuex無法觀察到值變化怎么解決”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。