国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vue實現(xiàn)雙向數(shù)據(jù)綁定

2024-05-06 15:17:40
字體:
供稿:網(wǎng)友

Vue實現(xiàn)雙向數(shù)據(jù)綁定的方式,具體內(nèi)容如下

Vue是如何實現(xiàn)雙向數(shù)據(jù)綁定的呢?答案是前端數(shù)據(jù)劫持。其通過Object.defineProperty()方法,這個方法可以設(shè)置getter和setter函數(shù),在setter函數(shù)中,就可以監(jiān)聽到數(shù)據(jù)的變化,從而更新綁定的元素的值。

實現(xiàn)對象屬性變化綁定到UI

大概的思路是:

1. 確定綁定的數(shù)據(jù),使用Object.defineProperty()對其數(shù)據(jù)變化進行監(jiān)聽(對應defineGetAndSet)
2. 一旦數(shù)據(jù)發(fā)生改動,會觸發(fā)setter函數(shù)。因此在setter函數(shù)內(nèi)要調(diào)用回調(diào)函數(shù)觸發(fā)綁定元素的更新。
3. 綁定元素的更新就是遍歷所有的綁定元素,通過綁定屬性的值確定函數(shù)的調(diào)用,并傳入修改后的值。(對應scan)

實現(xiàn)UI變化綁定到對象屬性

這個就比較簡單了,因為UI的改變會觸發(fā)一些事件,比如keyup。通過監(jiān)聽事件來實現(xiàn)數(shù)據(jù)的改變。而上面說了,數(shù)據(jù)的改變又會導致綁定其值的元素的UI改變。

實現(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 })} //一開始先初始化,使所有綁定的元素值為初始值scan();//設(shè)置需要被劫持的元素defineGetAndSet(data, 'value');//監(jiān)聽UI變化bindelems[1].addEventListener('keyup', function(e) { data.value = e.target.value;});setTimeout(function() { data.value = 'change';}, 1000);

參考:

javascript實現(xiàn)數(shù)據(jù)雙向綁定的三種方式

剖析Vue原理&實現(xiàn)雙向綁定MVVM

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 化德县| 铜陵市| 翁源县| 理塘县| 蛟河市| 交城县| 丰宁| 新津县| 河北区| 双鸭山市| 九龙县| 息烽县| 双桥区| 天水市| 修文县| 南陵县| 美姑县| 县级市| 淮阳县| 元氏县| 封丘县| 谷城县| 陆河县| 无极县| 宁晋县| 蓬安县| 宜兰市| 葫芦岛市| 台南市| 英超| 涿州市| 达孜县| 安顺市| 梅河口市| 常州市| 山丹县| 藁城市| 新竹县| 德钦县| 天津市| 吐鲁番市|