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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue 實現(xiàn)根據(jù)data中的屬性值來設置不同的樣式
這篇文章主要介紹了vue 實現(xiàn)根據(jù)data中的屬性值來設置不同的樣式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08vue-cli2 構建速度優(yōu)化的實現(xiàn)方法
這篇文章主要介紹了vue-cli2 構建速度優(yōu)化的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01探秘Vue異步更新機制中nextTick的原理與實現(xiàn)
nextTick?是?Vue?提供的一個重要工具,它的作用主要體現(xiàn)在幫助我們更好地處理異步操作,下面就跟隨小編一起來探索一下nextTick的原理與實現(xiàn)吧2024-02-02vue集成kindeditor富文本的實現(xiàn)示例代碼
這篇文章主要介紹了vue集成kindeditor富文本的實現(xiàn)示例代碼,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-06-06vue+d3js+fastapi實現(xiàn)天氣柱狀圖折線圖餅圖的示例
本文主要介紹了vue+d3js+fastapi實現(xiàn)天氣柱狀圖折線圖餅圖的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-04-04vue2.0嵌套路由實現(xiàn)豆瓣電影分頁功能(附demo)
這篇文章主要介紹了vue2.0嵌套路由實現(xiàn)豆瓣電影分頁功能(附demo),這里整理了詳細的代碼,有需要的小伙伴可以參考下。2017-03-03