Vue實(shí)現(xiàn)雙向數(shù)據(jù)綁定
Vue實(shí)現(xiàn)雙向數(shù)據(jù)綁定的方式,具體內(nèi)容如下
Vue是如何實(shí)現(xiàn)雙向數(shù)據(jù)綁定的呢?答案是前端數(shù)據(jù)劫持。其通過(guò)Object.defineProperty()方法,這個(gè)方法可以設(shè)置getter和setter函數(shù),在setter函數(shù)中,就可以監(jiān)聽(tīng)到數(shù)據(jù)的變化,從而更新綁定的元素的值。
實(shí)現(xiàn)對(duì)象屬性變化綁定到UI
大概的思路是:
1. 確定綁定的數(shù)據(jù),使用Object.defineProperty()對(duì)其數(shù)據(jù)變化進(jìn)行監(jiān)聽(tīng)(對(duì)應(yīng)defineGetAndSet)
2. 一旦數(shù)據(jù)發(fā)生改動(dòng),會(huì)觸發(fā)setter函數(shù)。因此在setter函數(shù)內(nèi)要調(diào)用回調(diào)函數(shù)觸發(fā)綁定元素的更新。
3. 綁定元素的更新就是遍歷所有的綁定元素,通過(guò)綁定屬性的值確定函數(shù)的調(diào)用,并傳入修改后的值。(對(duì)應(yīng)scan)
實(shí)現(xiàn)UI變化綁定到對(duì)象屬性
這個(gè)就比較簡(jiǎn)單了,因?yàn)閁I的改變會(huì)觸發(fā)一些事件,比如keyup。通過(guò)監(jiān)聽(tīng)事件來(lái)實(shí)現(xiàn)數(shù)據(jù)的改變。而上面說(shuō)了,數(shù)據(jù)的改變又會(huì)導(dǎo)致綁定其值的元素的UI改變。
實(shí)現(xiàn)
var data = { value: 'hello world!' } var bindValue; //確定綁定的元素 var bindelems = [document.getElementById('p'), document.getElementById('input')]; //修改綁定元素的值的方法 var command = { text: function(str) { this.innerHTML = str; }, value: function(str) { this.value = str; } }; //遍歷綁定元素修改其值 var scan = function() { console.log('in scan'); for(var i = 0; i < bindelems.length; i++) { var elem = bindelems[i]; console.log('elem',elem); for(var j = 0; j < elem.attributes.length; j++) { var attr = elem.attributes[j]; if(attr.nodeName.indexOf('q-')>=0) { command[attr.nodeName.slice(2)].call(elem, data[attr.nodeValue]); } } } } //設(shè)置劫持 var defineGetAndSet = function(obj, propname) { Object.defineProperty(obj, propname, { get: function() { return bindValue; }, set: function(value){ bindValue = value; scan(); }, enumerable: true, configurable: true }) } //一開(kāi)始先初始化,使所有綁定的元素值為初始值 scan(); //設(shè)置需要被劫持的元素 defineGetAndSet(data, 'value'); //監(jiān)聽(tīng)UI變化 bindelems[1].addEventListener('keyup', function(e) { data.value = e.target.value; }); setTimeout(function() { data.value = 'change'; }, 1000);
參考:
javascript實(shí)現(xiàn)數(shù)據(jù)雙向綁定的三種方式
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解Vue雙向數(shù)據(jù)綁定原理解析
- 輕松理解vue的雙向數(shù)據(jù)綁定問(wèn)題
- vue雙向數(shù)據(jù)綁定原理探究(附demo)
- Vue.js實(shí)現(xiàn)雙向數(shù)據(jù)綁定方法(表單自動(dòng)賦值、表單自動(dòng)取值)
- 使用Vue如何寫(xiě)一個(gè)雙向數(shù)據(jù)綁定(面試常見(jiàn))
- 通過(guò)源碼分析Vue的雙向數(shù)據(jù)綁定詳解
- vue雙向數(shù)據(jù)綁定知識(shí)點(diǎn)總結(jié)
- vue實(shí)現(xiàn)的雙向數(shù)據(jù)綁定操作示例
- vue 雙向數(shù)據(jù)綁定的實(shí)現(xiàn)學(xué)習(xí)之監(jiān)聽(tīng)器的實(shí)現(xiàn)方法
- vue.js使用v-model實(shí)現(xiàn)表單元素(input) 雙向數(shù)據(jù)綁定功能示例
相關(guān)文章
vue安裝遇到的5個(gè)報(bào)錯(cuò)及解決方法
在本篇文章里小編給大家分享了關(guān)于vue安裝遇到的5個(gè)報(bào)錯(cuò)小結(jié)以及解決方法,需要的朋友們參考下。2019-06-06vue-star評(píng)星組件開(kāi)發(fā)實(shí)例
下面小編就為大家分享一篇vue-star評(píng)星組件開(kāi)發(fā)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03在React和Vue中使用Mock.js模擬接口的實(shí)現(xiàn)方法
本文將介紹如何在React和Vue項(xiàng)目中使用Mock.js來(lái)模擬接口攔截請(qǐng)求,幫助開(kāi)發(fā)者在不依賴后端的情況下高效地進(jìn)行前端開(kāi)發(fā),文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下2024-08-08vue對(duì)插件(iview,elementui,treeselect)樣式的局部修改方式
這篇文章主要介紹了vue對(duì)插件(iview,elementui,treeselect)樣式的局部修改方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07關(guān)于element-ui resetFields重置方法無(wú)效問(wèn)題及解決
這篇文章主要介紹了關(guān)于element-ui resetFields重置方法無(wú)效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08