vue雙向綁定的含義是:當(dāng)數(shù)據(jù)發(fā)生變化時(shí),視圖也會(huì)發(fā)生變化;視圖一旦發(fā)生變化,數(shù)據(jù)也會(huì)跟著同步變化。數(shù)據(jù)雙向綁定的核心方法是“Object.defineProperty(obj,prop,descriptor)”。
本文操作環(huán)境:windows10系統(tǒng)、Vue2.9.6版,DELL G3電腦。
vue雙向綁定的概念含義是什么
vue是一個(gè)mvvm框架,即數(shù)據(jù)雙向綁定
即當(dāng)數(shù)據(jù)發(fā)生變化的時(shí)候,視圖也就發(fā)生變化,當(dāng)視圖發(fā)生變化的時(shí)候,數(shù)據(jù)也會(huì)跟著同步變化。
這也算是vue的精髓之處了。值得注意的是,我們所說(shuō)的數(shù)據(jù)雙向綁定,一定是對(duì)于UI控件來(lái)說(shuō)的,非UI控件不會(huì)涉及到數(shù)據(jù)雙向綁定。 單向數(shù)據(jù)綁定是使用狀態(tài)管理工具(如redux)的前提。如果我們使用vuex,那么數(shù)據(jù)流也是單項(xiàng)的,這時(shí)就會(huì)和雙向數(shù)據(jù)綁定有沖突。
為什么要實(shí)現(xiàn)數(shù)據(jù)的雙向綁定?
在vue中,如果使用vuex,實(shí)際上數(shù)據(jù)還是單向的,之所以說(shuō)是數(shù)據(jù)雙向綁定,這是用的UI控件來(lái)說(shuō),對(duì)于我們處理表單,vue的雙向數(shù)據(jù)綁定用起來(lái)就特別舒服了。
即兩者并不互斥, 在全局性數(shù)據(jù)流使用單項(xiàng),方便跟蹤; 局部性數(shù)據(jù)流使用雙向,簡(jiǎn)單易操作。
Vue的雙向綁定,核心是Object.defineProperty()方法,那接下來(lái)我們就簡(jiǎn)單介紹一下!
語(yǔ)法:
Object.defineProperty(obj,prop,descriptor)
其中:
obj
要在其上定義屬性的對(duì)象。
prop
要定義或修改的屬性的名稱。
descriptor
將被定義或修改的屬性描述符。
其實(shí),簡(jiǎn)單點(diǎn)來(lái)說(shuō),就是通過(guò)此方法來(lái)定義一個(gè)值。
調(diào)用,使用到了get方法,
賦值,使用到了set方法。
【