最近在工作中遇到了getter和setter,getter 是一種獲得屬性值的方法,setter是一種設定屬性值的方法。以下這篇文章主要為大家介紹了關於Javascript中getter和setter的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
前言
本文主要介紹給大家介紹的關於Javascript中getter和setter的相關內容,第一次聽到這個東西的時候是vue.js裡面的數據綁定,只要綁定了數據,修改對象屬性可以自動反饋到dom上,很神奇,後面也看到了文檔裡面實現是對對象定義了getter和setter並覆蓋原屬性,索性就來總結這兩者的用法,下面話不多說了,來一起看看詳細的介紹吧。
原理
利用Object.defineProperty重寫物件屬性為getter和setter,透過getter和setter順便改變綁定DOM節點的值
範例
摘自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 }]
利用這個MDN範例小小的寫了個方法並寫了個計時器的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; }); } } /* 例子很简单,直接改变对象属性,就直接 反馈到了DOM上,就好像是一个钩子,改变 这个对象的属性,这个属性的钩子把它绑 定的DOM的数据进行修改 */ 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>
以上是Javascript中getter和setter基本介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!