欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中$nexttick,$set,$forceupdate的區(qū)別

 更新時間:2023年07月24日 09:30:24   作者:阿Q--小黑  
本文主要介紹了vue中$nexttick,$set,$forceupdate的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

想必很多小伙伴在使用vue時,都遇到過明明修改data里的數(shù)據(jù)了,但是視圖卻不更新的情況吧,這時候有經(jīng)驗的小伙伴,二話不說直接調(diào)用this.$forceupdate()強制更新頁面,管他啥情況,刷就完事了,我屬于是整個一個大無語。

$nexttick

將回調(diào)延遲到下次 DOM 更新循環(huán)之后執(zhí)行。在修改數(shù)據(jù)之后立即使用它,然后等待 DOM 更新。它跟全局方法 Vue.nextTick 一樣,不同的是回調(diào)的 this 自動綁定到調(diào)用它的實例上。

上面摘抄自vue官網(wǎng),很多小伙伴可能看不懂,首先你要先知道vue的異步更新隊列。

可能你還沒有注意到,Vue是異步執(zhí)行DOM更新的,一旦觀察到數(shù)據(jù)變化,Vue就會開啟一個隊列,然后把在同一個事件循環(huán)(event loop)中觀察到的數(shù)據(jù)變化的watcher推送進這個隊列。如果這個watcher被觸發(fā)多次,只會被推送到隊列一次。這種緩沖行為可以有效去掉重復數(shù)據(jù)造成不必要的計算和DOM操作。而在下一個事件循環(huán)時,Vue會清空隊列,并進行必要的DOM更新。

“說的啥玩意兒,一句沒看懂”

“蒸滴撈,這都看不懂,給你打個比方,如果你要修改一個數(shù)據(jù),還連續(xù)修改了很多次,程序總不能不斷更新n次視圖叭,這也太消耗性能了,所以實際上vue只會在你改了半天數(shù)據(jù)后,對你最終的結果進行更新。懂了嗎?”

“哇,這么牛嗎,那nextick是怎么回事呢?”

“聽好了,哥一句話讓你頓悟,它其實就是用來知道什么時候DOM更新完成的。”

“666,不明覺厲,但是知道了有什么用呢?”

“比如你在修改數(shù)據(jù)之后,想要操作dom,你經(jīng)常會發(fā)現(xiàn)獲取到dom綁定的值還是舊值”

小明突然大聲喊道:“啊對對對,就是這樣,煩死我了,怎么解決它呢”

“別急,你要先知道為什么,其實就是剛剛說的,你改了數(shù)據(jù),它還擱那兒排序等著看你最后的結果呢,這時候dom還沒更新。所以如果你想拿到新值,nexttick就派上用場了。因為它能知道dom的更新時間,你就可以在它的回調(diào)函數(shù)里去進行操作,就能拿到新值了”

“哇,學到了,感謝大佬,還有個問題,怎么我總聽說別人用$nexttick更新視圖,我聽你這意思它并沒有起到更新視圖的作用啊”

“小伙子有長進,還能看出點東西。是的,網(wǎng)上總有些人亂扯,說用$nexttick更新視圖,其實它只是讓你的操作在視圖更新后才執(zhí)行而已”

“好的,謝謝大佬,我這就拿個小本本記下來”

$set

向響應式對象中添加一個 property,并確保這個新 property 同樣是響應式的,且觸發(fā)視圖更新。它必須用于向響應式對象上添加新 property,因為 Vue 無法探測普通的新增 property (比如 this.myObject.newProperty = ‘hi’)

數(shù)據(jù)更新但視圖沒更新,這種情況往往是我們定義了個對象,給這個對象添加了新的屬性。

我們要知道,vue2的雙向綁定原理它是通過Object.defineProperty()實現(xiàn)的,在初始化時,vue會把data中的數(shù)據(jù)加工成響應式的。然而如果你往這個數(shù)據(jù)上添加了新屬性,顯然,它沒有被加工成響應式數(shù)據(jù),那么視圖怎么會更新呢?

“那我該怎么做才能刷新視圖呢?”

“你分析一下就能想到,無非就是兩種方案,一種是把新加的屬性添加響應式,一種就是管他響應不響應的,用硬辦法強制刷新下頁面”

“愿聞其翔”

“第一種就是這里要說的$set,這是vue提供的api,你用它給對象添加屬性就可以了”

“好的,我去看看怎么用”

“不用麻煩了,很簡單的,看下面”

// 錯誤寫法:
this.$set(key,value)(ps: 可能是vue1.0的寫法)
mounted () {
? ? this.$set(this.student.age, 24)
}
// 正確寫法:
this.$set(this.data,”key”,value')

$forceupdate

迫使 Vue 實例重新渲染。注意它僅僅影響實例本身和插入插槽內(nèi)容的子組件,而不是所有子組件。

$forceUpdate的原理很簡單,即使強制觸發(fā)update聲明周期,重新渲染下dom:

Vue.prototype.$forceUpdate = function () {
    const vm: Component = this
    if (vm._watcher) {
        vm._watcher.update()
    }
}

總結

$nexttick并不是真正意義上的更新視圖,而是等視圖更新后再執(zhí)行某些操作

雖然 $ forceUpdate和$set都能起到更新視圖的效果,但是前者并不推薦使用,一是,官方都說了,如果你都到了要用 $ forceupdate的地步了,那你十有八九是操作有問題;二是能用 $ set解決的問題,為什么要用$forceupdate這種更消耗性能的方法呢,如果用了,估計是你偷懶!

到此這篇關于vue中$nexttick,$set,$forceupdate的區(qū)別的文章就介紹到這了,更多相關vue $nexttick,$set,$forceupdate內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論