亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mvvm雙向綁定機(jī)制的原理和實現(xiàn)代碼(推薦)

 更新時間:2016年06月07日 15:29:52   投稿:jingxian  
下面小編就為大家?guī)硪黄猰vvm雙向綁定機(jī)制的原理和實現(xiàn)代碼(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

mvvm框架的雙向綁定,即當(dāng)對象改變時,自動改變相關(guān)的dom元素的值,反之,當(dāng)dom元素改變時,能自動更新對象的值,當(dāng)然dom元素一般是指可輸出的input元素。

1. 首先實現(xiàn)單向綁定,在指定對象的屬性值發(fā)生改變時觸發(fā)callback函數(shù)。

2. 單向綁定可采用ES5新增的defineProperty實現(xiàn)(或defineProperties),用了ES5注定就不支持IE9以下了,為了防止遞歸死循環(huán)問題,原有屬性需要剪切到一個私有屬性中保存。

3. 循環(huán)調(diào)用defineProperty定義閉包時產(chǎn)生作用域的問題,為解決作用域變量對象的值會取到最后一次運行值問題,多定義一層立即調(diào)用的閉包函數(shù)將值傳入。

4. 我們定義getFN和setFN函數(shù)用于在屬性get和set的時候觸發(fā),它的功能是對私有屬性__private的讀寫并觸發(fā)回調(diào)函數(shù)通知UI層更新界面。

5.單向綁定實現(xiàn)完成后,實現(xiàn)反向的綁定,即UI層onchange之后觸發(fā)更新數(shù)據(jù),這個相對比較容易,在dom中通過自定義屬性bindKey關(guān)聯(lián)model的值變化,監(jiān)聽使用oninput事件,相比onchange的好處是可以實時變化不用等失焦,而且對右鍵粘貼、菜單粘貼,拖動文字進(jìn)文本框等方式都可以觸發(fā),完全無死角,缺點是只支持IE9以上,但是在IE9以下有等價的onpropertychange可以用還是能兼容的。

6.總結(jié),雙向綁定的原理并不復(fù)雜,整體代碼不超過50行,非常精簡,不過還是有一些技術(shù)含量,下面是完整的代碼,如果不想使用龐大的框架,可以用一下。ie9以下是不支持的,如要支持ie9以下可以使用avalon,它用vbs做了get,set存取器的封裝,這點還是比較強(qiáng)大的。

html:

<div id="container">
  <p>
  name:<input type="text" bindkey="userName">
  </p>
  <p>
  age:<input type="text" bindkey="age">
  </p>
<div>

js:

<script type="text/javascript">
  window.Model={
    userName:"windy",
    age:34,
    skill:["javascript","html","css","jquery","node"],
    
  }
  function bindingModel(model,changeCallback){
    var propertiesMap={};
    model.__private={};
    function getFn(name){
      var result=this.__private[name]
      console.log("get value:"+name+"="+ result);
      return result;
    };
    function setFn(name,val){
      if(this.__private[name]!=val){
        console.log("set value:"+name+"="+val);
       
        this.__private[name]=val;

        if(changeCallback){
          changeCallback(name,val);
        }
      }
    };
    for(elem in model){
      if(model.hasOwnProperty(elem) && elem!="__private" && typeof(model[elem])!="function"){
        (function(propName,propValue){
          model.__private[propName]=propValue;// init value
          propertiesMap[propName]={
            get:function(){ return getFn.call(this,propName)},
            set:function(v){ return setFn.call(this,propName,v)},
            //value:model[elem],
            //writable: true,
            enumerable: true,
            configurable: true
          }
        })(elem,model[elem]);
      }
    }
    Object.defineProperties(model,propertiesMap)
    
  }
  function bindingBoth(model,dom){
    dom.find("[bindkey]").each(function(item){
      var key=$(this).attr("bindkey");
      $(this).val(model[key]);
      $(this).bind("input",function(){
        model[key]=$(this).val();
      })
    });
    bindingModel(model,function(name,val){
      var el=dom.find("[bindkey="+name+"]");
      if(el.val()!=val){
        el.val(val);
      }
      
    });
  }
  bindingBoth(window.Model,$("#container"))
  </script>

以上這篇mvvm雙向綁定機(jī)制的原理和實現(xiàn)代碼(推薦)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論