vue中data改變后讓視圖同步更新的方法
前言
不久前天看到一個比較有趣的問題,vue中data改變后,如何讓視圖同步更新,搜索了一下,并沒有發(fā)現(xiàn)解決問題的方法,只能從源碼去找解決方法了。
原因
我們都知道,在vue中改變數(shù)據(jù)后,視圖并不是同步更新的。
在vue實例初始化后,會將data設(shè)置為響應(yīng)式對象,當我們執(zhí)行this.xxx = 1時,會觸發(fā)這個響應(yīng)式對象的setter。在setter中,會觸發(fā)更新,通知所有訂閱了xxx的訂閱者。但是這個觸發(fā)更新并不是同步的,它會將所有的watcher都添加到一個隊列,并在nextTick之后去更新視圖。
這就是vue不能同步更新視圖的原因。
解決方法
知道了原因,總能找到解決方法。
既然是在nextTick的時候去更新視圖,這個時候,必然會去執(zhí)行一個更新視圖的方法,那么我們手動在數(shù)據(jù)改變的時候去執(zhí)行這個方法,就達到了同步更新視圖的目的。
在了解源碼后,我們可以發(fā)現(xiàn)執(zhí)行的是watcher.run()這個方法,那么問題來了,怎么去獲取這個方法?
想快速了解這一塊建議閱讀 Vue.js技術(shù)揭秘
我們在控制臺打印一下this
可以在_watcher這個對象的原型上找到run這個方法,因此問題就解決了。
this.xxx = 1; this._watcher.run()
執(zhí)行以上代碼,在更新完數(shù)據(jù)后,手動更新視圖,就可以做到同步的效果。
更好的解決方法
如果每次想要視圖同步更新都要加一句 this._watcher.run() ,那豈不是太麻煩了,因此,我寫了一個插件,支持this.xxx = 1 之后就同步更新視圖。
這個插件原理很簡單,就是在組件的options里邊加了一個選項syncData,跟data是類似的,然后放入data里面,created鉤子調(diào)用的時候重新劫持這部分數(shù)據(jù),syncData里邊數(shù)據(jù)改變的時候,自動觸發(fā)_watch.run(),從而同步更新視圖。
插件地址:GitHub地址
后記
講道理我覺得這個插件并沒有什么卵用,理論上這個插件能解決的問題$nextTick都可以解決。
到此這篇關(guān)于vue中data改變后讓視圖同步更新的方法的文章就介紹到這了,更多相關(guān)vue視圖同步更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue2.0+koa2+mongodb實現(xiàn)注冊登錄
這篇文章主要介紹了vue2.0+koa2+mongodb實現(xiàn)注冊登錄功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2018-04-04vue 點擊其他區(qū)域關(guān)閉自定義div操作
這篇文章主要介紹了vue 點擊其他區(qū)域關(guān)閉自定義div操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07vue3+echarts+折線投影(陰影)效果的實現(xiàn)
這篇文章主要介紹了vue3+echarts+折線投影(陰影)效果的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10vue中使用webuploader做斷點續(xù)傳實現(xiàn)文件上傳功能
之前做的一個項目中,由于經(jīng)常上傳幾百兆的壓縮包,導(dǎo)致經(jīng)常上傳失敗,所以就找了webuploader插件做了斷點續(xù)傳,斷點續(xù)傳除了需要前端分片,也需要后臺去支持,所以做的時候做好對接協(xié)調(diào),所以本文就給大家詳細的介紹一下vue中如何使用webuploader做斷點續(xù)傳2023-07-07