今天就跟大家聊聊有關使用JavaScript怎么實現(xiàn)數(shù)據(jù)雙向綁定,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據(jù)這篇文章可以有所收獲。
創(chuàng)新互聯(lián)是一家專業(yè)提供麥積企業(yè)網(wǎng)站建設,專注與網(wǎng)站設計、成都網(wǎng)站設計、HTML5、小程序制作等業(yè)務。10年已為麥積眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡公司優(yōu)惠進行中。可以定義一個構造函數(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) } }
看完上述內容,你們對使用JavaScript怎么實現(xiàn)數(shù)據(jù)雙向綁定有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司行業(yè)資訊頻道,感謝大家的支持。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
新聞標題:使用JavaScript怎么實現(xiàn)數(shù)據(jù)雙向綁定-創(chuàng)新互聯(lián)
當前網(wǎng)址:http://www.rwnh.cn/article26/cceicg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供服務器托管、網(wǎng)站設計、面包屑導航、移動網(wǎng)站建設、標簽優(yōu)化、外貿網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容