前言
本文主要给大家介绍的关于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>
参考
Object.defineProperty() - JavaScript | MDN
深入响应式原理 — Vue.js
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“Javascript中的getter和setter初识”评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2025年01月14日
2025年01月14日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]