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

js實現(xiàn)視圖和數(shù)據(jù)雙向綁定的方法分析

 更新時間:2020年02月05日 10:13:13   作者:米彩  
這篇文章主要介紹了js實現(xiàn)視圖和數(shù)據(jù)雙向綁定的方法,結合實例形式分析了vue.js及jQuery數(shù)據(jù)綁定相關操作技巧與注意事項,需要的朋友可以參考下

本文實例講述了js實現(xiàn)視圖和數(shù)據(jù)雙向綁定的方法。分享給大家供大家參考,具體如下:

前言

視圖和數(shù)據(jù)綁定,使視圖和邏輯層分離,使視圖層變?yōu)閿?shù)據(jù)驅動是前端的一大進步。由此誕生了mvvm類的前端框架,大大提升了開發(fā)的效率。

那么在使用舊有的項目中,如何使用更加先進的設計模式來替換掉大量的面向過程編程。

各大框架對于數(shù)據(jù)綁定的實現(xiàn)都有各自的方式,這里不做深入只是簡單介紹一下。

Vue使用了es5  Object.defineProperty的特性來實現(xiàn)對數(shù)據(jù)讀取和設置的監(jiān)聽,是一種元編程的方式。個人感覺,比之a(chǎn)ngularJS的臟檢查數(shù)據(jù)比對更新機制確實要科學一點。

Object.defineProperty實現(xiàn)了對數(shù)據(jù)get和set的重新編程,能讓我們在做最簡單的 = 賦值操作時來做一些事,具體的實現(xiàn)就不放在這了。這不是今天要討論的重點。

在低版本瀏覽器中顯然對于這點的支持也不夠友好,那么我可以想一種替代性的方案來達到和Object.defineProperty所類似的效果。在微信小程序中設置數(shù)據(jù)需要使用set方法,因為小程序的視圖層本質上是分離于js引擎的。這樣等于手動告訴視圖層某個數(shù)據(jù)更新了。那么我也可以使用這種方法來實現(xiàn)對數(shù)據(jù)更新的監(jiān)聽。

實現(xiàn)

首先我們需要一個對象來保存數(shù)據(jù)。并且在其數(shù)據(jù)變更時做一些事情??梢远x一個構造函數(shù)來獲得這個對象。

因為get和set方法很顯然是公共的,所以可以定義在原型對象上。

var $vm = function(obj) {
  this.data = obj.data
}
$vm.prototype.get = function(prop) {
  //返回當前值
  return this.data[prop]
}
$vm.prototype.set = function (prop, val) {
  //賦值操作
  this.data[prop] = val
}

如果這時候實例化一個這個構造函數(shù)的對象,這個對象上就會存在get和set方法,看代碼可以知道他對這個對象上的data生效。

這樣一個簡單的get set方法就設置好了。一個是獲取當前對象屬性的值,一個是對其設置新的值。

如果在設置的時候我們再去觸發(fā)相應的視圖層的操作,那么一個簡單的綁定就實現(xiàn)了。

var vm = new $vm({
  // 綁定的變量值
  data: {
    info: true
  }
})

取值

vm.get('info')

存值

vm.set('info', false)

如果我們在set方法里添加console.log()那么每次數(shù)據(jù)變動都會被打印出來。

使用set方法來替代=號的賦值操作可以一定意義上代替Object.defineProperty的效果。并且兼容性更好。

對視圖數(shù)據(jù)進行綁定是一個很大的問題,怎樣使數(shù)據(jù)的變動在視圖上體現(xiàn)。

這里一個最簡單的替代實現(xiàn)就是去手動綁定數(shù)據(jù)和視圖。用jq的方式。

比如在set里面執(zhí)行對應這個屬性變動的回掉函數(shù)。

例如

$vm.prototype.set = function (prop, val) {
  this.data[prop] = val
  if (this.$$fn[prop]) {
    this.$$fn[prop](val, oldVal)
  }
}

可以看到如果當前對象上$$fn屬性上如果存在同名的函數(shù),會執(zhí)行。

這樣我們可以把綁定dom的操作來放到里面顯示。

這種寫法顯然可能不太利于維護,于是我想可以參照vue框架的watch觀察者來實現(xiàn)。

在vue中觀察對象上某個值的改變可以do someThing。

所以在此可以借鑒。

// 存值
$vm.prototype.set = function (prop, val) {
    var oldVal = this.data[prop]
    this.data[prop] = val
 
    //如果發(fā)現(xiàn)被列入觀察者 執(zhí)行函數(shù)并注入修改后的值
    if (this.watch[prop]) {
      this.watch[prop](val, oldVal)
    }
}

鴿了,這里省略3000字。哈哈哈哈,因為寫了好多代碼但是沒寫博客,懶得寫了直接跳過吧,有興趣的童鞋直接看源碼。虛擬dom和{{}}表達式,觀察者模式,計算屬性等等。

突發(fā)奇想,想要對數(shù)據(jù)層綁定還有個簡單的方案。利用html data的自定義屬性來綁定相應的屬性,利用jq選擇器來找到對應的節(jié)點進行更新。這也是一種替代的方案。

JQ選擇器,選擇屬性=某值的dom節(jié)點。利用這個選擇器可以來獲得所有綁定了某屬性的節(jié)點。

<div data-vm="info">
</div>

$('[data-vm="info"]').text(300)

這個節(jié)點的值變?yōu)榱?00。

所以利用自定義屬性和jq的選擇器,只要在dom節(jié)點上寫上data-vm(取的名字)然后等于要綁定的值,那么就可以實現(xiàn)對視圖的綁定了。

// 存值
$vm.prototype.set = function (prop, val) {
  try {
    var oldVal = this.data[prop]
    this.data[prop] = val
    //如果發(fā)現(xiàn)被列入觀察者 執(zhí)行函數(shù)并注入修改后的值
    if (this.watch[prop]) {
      this.watch[prop](val, oldVal)
    }
    //查詢是否有訂閱值
    if (this.$$fn[prop]) {
      this.$$fn[prop](val, oldVal)
    }
    //查詢是否有依賴于此項的計算屬性
    if (this.$$count[prop]) {
      // 獲得所有依賴此值的計算屬性
      var arr = this.$$count[prop]
      //循環(huán)遍歷每個計算屬性并重新計算它的值
      for (var i = 0; i < arr.length; i++) {
        var item = arr[i]
        // 獲得返回的值
        this.data[item] = this.computed[item]()
      }
    }
    // 如果節(jié)點綁定了此屬性 更新節(jié)點
    var dom = $('[data-vm="' + prop + '"]')
    if (dom) {
      dom.text(val)
    }
    // this.updateView()
  } catch(e) {
    console.log('error setData' + prop)
  }
}

實現(xiàn)成功!

目前綁定的各種方式我改了蠻多,具體的代碼在github上,有興趣的童鞋可以看一看。

項目github地址https://github.com/unjust-life/mvvm

更多關于JavaScript相關內(nèi)容可查看本站專題:《JavaScript操作DOM技巧總結》、《JavaScript頁面元素操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript查找算法技巧總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript錯誤與調(diào)試技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • JavaScript中神奇的call()方法

    JavaScript中神奇的call()方法

    這篇文章主要介紹了JavaScript中神奇的call()方法,本文用淺顯的語言幫助你加深理解call()方法,需要的朋友可以參考下
    2015-03-03
  • 淺析BootStrap Treeview的簡單使用

    淺析BootStrap Treeview的簡單使用

    bootstrap-treeview.js1是一款強大的樹菜單插件,本文給大家介紹bootstrap treeview的簡單使用,涉及到使用要求及數(shù)據(jù)格式的介紹,本文介紹的非常詳細,具有參考借鑒價值,感興趣的朋友參考下
    2016-10-10
  • JS小功能(offsetLeft實現(xiàn)圖片滾動效果)實例代碼

    JS小功能(offsetLeft實現(xiàn)圖片滾動效果)實例代碼

    這篇文章主要介紹了offsetLeft實現(xiàn)圖片滾動效果實例代碼,有需要的朋友可以參考一下
    2013-11-11
  • 前端js?sm2實現(xiàn)加密簡單代碼舉例

    前端js?sm2實現(xiàn)加密簡單代碼舉例

    在Vue項目中實現(xiàn)數(shù)據(jù)加密,首先需要安裝SM2加密庫,如js-sm2或sm-crypto,通過npm或yarn進行安裝后,在Vue組件或文件中引入該庫,并使用其提供的加密、解密功能,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-09-09
  • IE事件對象(The Internet Explorer Event Object)

    IE事件對象(The Internet Explorer Event Object)

    不同于DOM事件對象,基于Event Handler授權這種方式,IE事件對象可以用不同的方式進行訪問。當一個事件Handler通過DOM 0 級的方式被授權,則這個事件對象將作為window對象的屬性而存在
    2012-06-06
  • js壓縮利器

    js壓縮利器

    這篇文章主要介紹了js壓縮利器
    2007-02-02
  • 詳解為Bootstrap Modal添加拖拽的方法

    詳解為Bootstrap Modal添加拖拽的方法

    本篇文章主要介紹了詳解為Bootstrap Modal添加拖拽的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • js函數(shù)獲取html中className所在的內(nèi)容并去除標簽

    js函數(shù)獲取html中className所在的內(nèi)容并去除標簽

    本文為大家介紹下如何使用js函數(shù)獲取html中className所在的內(nèi)容,具體實現(xiàn)思路如下,喜歡的朋友可以參考下
    2013-09-09
  • JavaScript圣杯布局與雙飛翼布局實現(xiàn)案例詳解

    JavaScript圣杯布局與雙飛翼布局實現(xiàn)案例詳解

    這篇文章主要介紹了JavaScript圣杯布局與雙飛翼布局實現(xiàn)案例,這是前端面試中需要掌握的知識點,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • JavaScript中按位“異或”運算符使用介紹

    JavaScript中按位“異或”運算符使用介紹

    按位“異或”運算符 (^)是對兩個表達式執(zhí)行按位異或,下面為大家介紹下其具體的使用方法
    2014-03-03

最新評論