Javascript中的getter和setter初識
前言
本文主要給大家介紹的關于Javascript中getter和setter的相關內容,第一次聽說這個東西的時候是vue.js里面的數(shù)據(jù)綁定,只要綁定了數(shù)據(jù),修改對象屬性可以自動反饋到dom上,很神奇,后面也看到了文檔里面實現(xiàn)是對對象定義了getter和setter并覆蓋原屬性,索性就來總結這兩者的用法,下面話不多說了,來一起看看詳細的介紹吧。
原理
利用Object.defineProperty來重寫對象屬性為getter和setter,通過getter和setter順便改變綁定DOM節(jié)點的值
例子
摘自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的數(shù)據(jù)進行修改
*/
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
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
前端不使用i18n該如何優(yōu)雅的實現(xiàn)多語言
多語言的重要性相信不需要多言,下面這篇文章主要給大家介紹了關于前端不使用i18n該如何優(yōu)雅的實現(xiàn)多語言,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2023-01-01
關于Javascript加載執(zhí)行優(yōu)化的研究報告
這篇文章主要介紹了關于Javascript加載執(zhí)行優(yōu)化的研究報告,需要的朋友可以參考下2014-12-12
JavaScript中訪問節(jié)點對象的方法有哪些如何使用
js訪問節(jié)點對象的方法有很多,比如getElementById在本文將舉例為大家介紹下2013-09-09

