溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue實現雙向數據綁定

發布時間:2020-10-05 17:56:32 來源:腳本之家 閱讀:148 作者:Front_end_lh 欄目:web開發

Vue實現雙向數據綁定的方式,具體內容如下

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

實現對象屬性變化綁定到UI

大概的思路是:

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

實現UI變化綁定到對象屬性

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

實現

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]);
 }
 }
 }
}
//設置劫持
var defineGetAndSet = function(obj, propname) {
 Object.defineProperty(obj, propname, {
 get: function() {
 return bindValue;
 },
 set: function(value){
 bindValue = value;
 scan();
 },
 enumerable: true,
 configurable: true
 })
} 
//一開始先初始化,使所有綁定的元素值為初始值
scan();
//設置需要被劫持的元素
defineGetAndSet(data, 'value');
//監聽UI變化
bindelems[1].addEventListener('keyup', function(e) {
 data.value = e.target.value;
});
setTimeout(function() {
 data.value = 'change';
}, 1000);

參考:

javascript實現數據雙向綁定的三種方式

剖析Vue原理&實現雙向綁定MVVM

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女