亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

使用JavaScript怎么實現數據雙向綁定

發布時間:2021-04-16 18:00:18 來源:億速云 閱讀:128 作者:Leah 欄目:web開發

今天就跟大家聊聊有關使用JavaScript怎么實現數據雙向綁定,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

可以定義一個構造函數來獲得這個對象。

因為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
}

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

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

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

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

取值

vm.get('info')

存值

vm.set('info', false)

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

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

對視圖數據進行綁定是一個很大的問題,怎樣使數據的變動在視圖上體現。

這里一個最簡單的替代實現就是去手動綁定數據和視圖。用jq的方式。

比如在set里面執行對應這個屬性變動的回掉函數。

例如

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

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

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

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

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

所以在此可以借鑒。

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

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

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

使用JavaScript怎么實現數據雙向綁定

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

<div data-vm="info">
</div>
$('[data-vm="info"]').text(300)

這個節點的值變為了300。

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

// 存值
$vm.prototype.set = function (prop, val) {
  try {
    var oldVal = this.data[prop]
    this.data[prop] = val
    //如果發現被列入觀察者 執行函數并注入修改后的值
    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]
      //循環遍歷每個計算屬性并重新計算它的值
      for (var i = 0; i < arr.length; i++) {
        var item = arr[i]
        // 獲得返回的值
        this.data[item] = this.computed[item]()
      }
    }
    // 如果節點綁定了此屬性 更新節點
    var dom = $('[data-vm="' + prop + '"]')
    if (dom) {
      dom.text(val)
    }
    // this.updateView()
  } catch(e) {
    console.log('error setData' + prop)
  }
}

看完上述內容,你們對使用JavaScript怎么實現數據雙向綁定有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

纳雍县| 安乡县| 普定县| 吉首市| 沙雅县| 日土县| 军事| 九龙坡区| 都兰县| 桂阳县| 垣曲县| 渭南市| 常山县| 丹凤县| 阜阳市| 乌什县| 崇明县| 柳州市| 大同县| 枞阳县| 九龙县| 丁青县| 伊金霍洛旗| 宿迁市| 辉县市| 道孚县| 雷波县| 资源县| 龙川县| 河池市| 鄱阳县| 友谊县| 民丰县| 普格县| 德化县| 长海县| 泸定县| 二连浩特市| 循化| 黎城县| 彰化县|