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

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

使用JavaScript怎么實(shí)現(xiàn)數(shù)據(jù)雙向綁定-創(chuàng)新互聯(lián)

今天就跟大家聊聊有關(guān)使用JavaScript怎么實(shí)現(xiàn)數(shù)據(jù)雙向綁定,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)是一家專業(yè)提供麥積企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)、HTML5、小程序制作等業(yè)務(wù)。10年已為麥積眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。

可以定義一個(gè)構(gòu)造函數(shù)來獲得這個(gè)對(duì)象。

因?yàn)間et和set方法很顯然是公共的,所以可以定義在原型對(duì)象上。

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

如果這時(shí)候?qū)嵗粋€(gè)這個(gè)構(gòu)造函數(shù)的對(duì)象,這個(gè)對(duì)象上就會(huì)存在get和set方法,看代碼可以知道他對(duì)這個(gè)對(duì)象上的data生效。

這樣一個(gè)簡(jiǎn)單的get set方法就設(shè)置好了。一個(gè)是獲取當(dāng)前對(duì)象屬性的值,一個(gè)是對(duì)其設(shè)置新的值。

如果在設(shè)置的時(shí)候我們?cè)偃ビ|發(fā)相應(yīng)的視圖層的操作,那么一個(gè)簡(jiǎn)單的綁定就實(shí)現(xiàn)了。

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

取值

vm.get('info')

存值

vm.set('info', false)

如果我們?cè)趕et方法里添加console.log()那么每次數(shù)據(jù)變動(dòng)都會(huì)被打印出來。

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

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

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

比如在set里面執(zhí)行對(duì)應(yīng)這個(gè)屬性變動(dòng)的回掉函數(shù)。

例如

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

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

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

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

在vue中觀察對(duì)象上某個(gè)值的改變可以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字。哈哈哈哈,因?yàn)閷懥撕枚啻a但是沒寫博客,懶得寫了直接跳過吧,有興趣的童鞋直接看源碼。虛擬dom和{{}}表達(dá)式,觀察者模式,計(jì)算屬性等等。

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

使用JavaScript怎么實(shí)現(xiàn)數(shù)據(jù)雙向綁定

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


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

這個(gè)節(jié)點(diǎn)的值變?yōu)榱?00。

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

// 存值
$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)
    }
    //查詢是否有依賴于此項(xiàng)的計(jì)算屬性
    if (this.$$count[prop]) {
      // 獲得所有依賴此值的計(jì)算屬性
      var arr = this.$$count[prop]
      //循環(huán)遍歷每個(gè)計(jì)算屬性并重新計(jì)算它的值
      for (var i = 0; i < arr.length; i++) {
        var item = arr[i]
        // 獲得返回的值
        this.data[item] = this.computed[item]()
      }
    }
    // 如果節(jié)點(diǎn)綁定了此屬性 更新節(jié)點(diǎn)
    var dom = $('[data-vm="' + prop + '"]')
    if (dom) {
      dom.text(val)
    }
    // this.updateView()
  } catch(e) {
    console.log('error setData' + prop)
  }
}

看完上述內(nèi)容,你們對(duì)使用JavaScript怎么實(shí)現(xiàn)數(shù)據(jù)雙向綁定有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝大家的支持。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


網(wǎng)站名稱:使用JavaScript怎么實(shí)現(xiàn)數(shù)據(jù)雙向綁定-創(chuàng)新互聯(lián)
新聞來源:http://weahome.cn/article/cceicg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部