Javascript中的getter和setter初識(shí)
前言
本文主要給大家介紹的關(guān)于Javascript中g(shù)etter和setter的相關(guān)內(nèi)容,第一次聽說(shuō)這個(gè)東西的時(shí)候是vue.js里面的數(shù)據(jù)綁定,只要綁定了數(shù)據(jù),修改對(duì)象屬性可以自動(dòng)反饋到dom上,很神奇,后面也看到了文檔里面實(shí)現(xiàn)是對(duì)對(duì)象定義了getter和setter并覆蓋原屬性,索性就來(lái)總結(jié)這兩者的用法,下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。
原理
利用Object.defineProperty來(lái)重寫對(duì)象屬性為getter和setter,通過(guò)getter和setter順便改變綁定DOM節(jié)點(diǎn)的值
例子
摘自MDN
function Archiver() { var temperature = null; var archive = []; Object.defineProperty(this, 'temperature', { get: function() { console.log('get!'); return temperature; }, set: function(value) { temperature = value; archive.push({ val: temperature }); } }); this.getArchive = function() { return archive; }; } var arc = new Archiver(); arc.temperature; // 'get!' arc.temperature = 11; arc.temperature = 13; arc.getArchive(); // [{ val: 11 }, { val: 13 }]
利用這個(gè)MDN例子小小的寫了個(gè)方法并寫了個(gè)計(jì)時(shí)器的DEMO
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <h1 id="testTime" z:bind="time">0s</h1> <script> // 雙向綁定 function bind_data(ele, arg){ var bindAttributeName = 'z:bind'; var data = JSON.parse(JSON.stringify(arg)) || {}; Object.keys(arg).forEach(function(argKey, index, array){ Object.defineProperty(arg, argKey, { get: function(){ return data[argKey]; }, set: function(value){ if(ele.getAttribute(bindAttributeName) !== argKey) { return; } if(ele.tagName === 'INPUT'){ ele.value = value; }else{ ele.innerHTML = value; } data[argKey] = value; } }); arg[argKey] = arg[argKey]; }); var key = ele.getAttribute(bindAttributeName); if((ele.tagName === 'INPUT' || ele.tagName === 'TEXTAREA') && arg[key]){ ele.addEventListener('input', function(e){ data[key] = ele.value; }); } } /* 例子很簡(jiǎn)單,直接改變對(duì)象屬性,就直接 反饋到了DOM上,就好像是一個(gè)鉤子,改變 這個(gè)對(duì)象的屬性,這個(gè)屬性的鉤子把它綁 定的DOM的數(shù)據(jù)進(jìn)行修改 */ var start = (new Date()).getTime(); var now; var b = {time: '0s'}; bind_data(document.getElementById('testTime'), b); setInterval(function(){ var now = (new Date()).getTime(); b.time = ((now - start)/1000) + 's' }, 1); </script> </body> </html>
參考
Object.defineProperty() - JavaScript | MDN
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
setTimeout自動(dòng)觸發(fā)一個(gè)js的方法
本文為大家介紹下使用setTimeout自動(dòng)觸發(fā)一個(gè)js,具體實(shí)現(xiàn)如下,喜歡的朋友可以學(xué)習(xí)下2014-01-01在JavaScript中使用inline函數(shù)的問(wèn)題
在JavaScript中使用inline函數(shù)的問(wèn)題...2007-03-03js實(shí)現(xiàn)3D旋轉(zhuǎn)相冊(cè)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)3D旋轉(zhuǎn)相冊(cè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08移動(dòng)端基礎(chǔ)事件總結(jié)與應(yīng)用
本文主要介紹了移動(dòng)端基礎(chǔ)事件總結(jié)與應(yīng)用,具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01js 簡(jiǎn)易版滾動(dòng)條實(shí)例(適用于移動(dòng)端H5開發(fā))
下面小編就為大家?guī)?lái)一篇js 簡(jiǎn)易版滾動(dòng)條實(shí)例(適用于移動(dòng)端H5開發(fā))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06