真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

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

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊、網(wǎng)站空間、營銷軟件、網(wǎng)站建設(shè)、濟(jì)南網(wǎng)站維護(hù)、網(wǎng)站推廣。

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

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

大概的思路是:

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

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

這個(gè)就比較簡單了,因?yàn)閁I的改變會(huì)觸發(fā)一些事件,比如keyup。通過監(jiān)聽事件來實(shí)現(xiàn)數(shù)據(jù)的改變。而上面說了,數(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
 })
} 
//一開始先初始化,使所有綁定的元素值為初始值
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實(shí)現(xiàn)數(shù)據(jù)雙向綁定的三種方式

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


分享名稱:Vue實(shí)現(xiàn)雙向數(shù)據(jù)綁定
網(wǎng)頁地址:http://weahome.cn/article/pdhisj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部