欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年05月03日 14:02:02   作者:Front_end_lh  
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)雙向數(shù)據(jù)綁定的方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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ù)雙向綁定的三種方式

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue2.0 自定義日期時(shí)間過(guò)濾器

    vue2.0 自定義日期時(shí)間過(guò)濾器

    本文給大家?guī)?lái)兩種方法實(shí)現(xiàn)vue2.0 自定義日期時(shí)間過(guò)濾器,需要的的朋友參考下吧
    2017-06-06
  • 詳解如何運(yùn)行vue項(xiàng)目

    詳解如何運(yùn)行vue項(xiàng)目

    這篇文章主要介紹了如何運(yùn)行vue項(xiàng)目,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • VUE正則表達(dá)式用法全集整理(推薦!)

    VUE正則表達(dá)式用法全集整理(推薦!)

    正則表達(dá)式是由一些特定的字符組成,代表一個(gè)規(guī)則,可以用來(lái)檢驗(yàn)數(shù)據(jù)格式是否合法,也可以在一段文本中查找滿足要求的內(nèi)容,這篇文章主要給大家介紹了關(guān)于VUE正則表達(dá)式用法的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • 如何在Vue項(xiàng)目中使用vuex

    如何在Vue項(xiàng)目中使用vuex

    這篇文章主要介紹了如何在Vue項(xiàng)目中使用vuex問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue安裝遇到的5個(gè)報(bào)錯(cuò)及解決方法

    vue安裝遇到的5個(gè)報(bào)錯(cuò)及解決方法

    在本篇文章里小編給大家分享了關(guān)于vue安裝遇到的5個(gè)報(bào)錯(cuò)小結(jié)以及解決方法,需要的朋友們參考下。
    2019-06-06
  • vue-star評(píng)星組件開(kāi)發(fā)實(shí)例

    vue-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中使用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-08
  • Vue3中嵌套路由和編程式路由的實(shí)現(xiàn)

    Vue3中嵌套路由和編程式路由的實(shí)現(xiàn)

    Vue?Router在Vue.js的核心庫(kù)上提供了路由的功能,使得我們可以在單頁(yè)應(yīng)用中實(shí)現(xiàn)頁(yè)面的切換、跳轉(zhuǎn)和參數(shù)傳遞等功能,本文主要介紹了Vue3中嵌套路由和編程式路由的實(shí)現(xiàn),感興趣的可以了解一下
    2023-12-12
  • vue對(duì)插件(iview,elementui,treeselect)樣式的局部修改方式

    vue對(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)題及解決

    這篇文章主要介紹了關(guān)于element-ui resetFields重置方法無(wú)效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評(píng)論