vue中data改變后讓視圖同步更新的方法
前言
不久前天看到一個(gè)比較有趣的問題,vue中data改變后,如何讓視圖同步更新,搜索了一下,并沒有發(fā)現(xiàn)解決問題的方法,只能從源碼去找解決方法了。
原因
我們都知道,在vue中改變數(shù)據(jù)后,視圖并不是同步更新的。
在vue實(shí)例初始化后,會(huì)將data設(shè)置為響應(yīng)式對象,當(dāng)我們執(zhí)行this.xxx = 1時(shí),會(huì)觸發(fā)這個(gè)響應(yīng)式對象的setter。在setter中,會(huì)觸發(fā)更新,通知所有訂閱了xxx的訂閱者。但是這個(gè)觸發(fā)更新并不是同步的,它會(huì)將所有的watcher都添加到一個(gè)隊(duì)列,并在nextTick之后去更新視圖。
這就是vue不能同步更新視圖的原因。
解決方法
知道了原因,總能找到解決方法。
既然是在nextTick的時(shí)候去更新視圖,這個(gè)時(shí)候,必然會(huì)去執(zhí)行一個(gè)更新視圖的方法,那么我們手動(dòng)在數(shù)據(jù)改變的時(shí)候去執(zhí)行這個(gè)方法,就達(dá)到了同步更新視圖的目的。
在了解源碼后,我們可以發(fā)現(xiàn)執(zhí)行的是watcher.run()這個(gè)方法,那么問題來了,怎么去獲取這個(gè)方法?
想快速了解這一塊建議閱讀 Vue.js技術(shù)揭秘
我們在控制臺(tái)打印一下this

可以在_watcher這個(gè)對象的原型上找到run這個(gè)方法,因此問題就解決了。
this.xxx = 1; this._watcher.run()
執(zhí)行以上代碼,在更新完數(shù)據(jù)后,手動(dòng)更新視圖,就可以做到同步的效果。
更好的解決方法
如果每次想要視圖同步更新都要加一句 this._watcher.run() ,那豈不是太麻煩了,因此,我寫了一個(gè)插件,支持this.xxx = 1 之后就同步更新視圖。
這個(gè)插件原理很簡單,就是在組件的options里邊加了一個(gè)選項(xiàng)syncData,跟data是類似的,然后放入data里面,created鉤子調(diào)用的時(shí)候重新劫持這部分?jǐn)?shù)據(jù),syncData里邊數(shù)據(jù)改變的時(shí)候,自動(dòng)觸發(fā)_watch.run(),從而同步更新視圖。
插件地址:GitHub地址
后記
講道理我覺得這個(gè)插件并沒有什么卵用,理論上這個(gè)插件能解決的問題$nextTick都可以解決。
到此這篇關(guān)于vue中data改變后讓視圖同步更新的方法的文章就介紹到這了,更多相關(guān)vue視圖同步更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ElementUI級(jí)聯(lián)選擇器實(shí)現(xiàn)同一父級(jí)下最多只能選中一個(gè)子級(jí)
本文主要介紹了ElementUI級(jí)聯(lián)選擇器實(shí)現(xiàn)同一父級(jí)下最多只能選中一個(gè)子級(jí),同一父級(jí)下的子節(jié)點(diǎn)單選,又可以選擇多個(gè)不同父級(jí)下的節(jié)點(diǎn),具有一定參考價(jià)值,感興趣的可以了解一下2023-10-10
Vue.js計(jì)算屬性computed與watch(5)
這篇文章主要為大家詳細(xì)介紹了Vue.js計(jì)算屬性computed與watch,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
vue實(shí)現(xiàn)綁定事件的方法實(shí)例代碼詳解
這篇文章主要介紹了vue實(shí)現(xiàn)綁定事件的方法實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
Vue實(shí)現(xiàn)組件間通信的幾種方式(多種場景)
本文主要介紹了Vue實(shí)現(xiàn)組件間通信的幾種方式,不同的場景使用不同的方式,基本滿足所有開發(fā)場景中的通信需求,感興趣的可以了解一下2021-10-10

