Javascript中的getter和setter初识


Posted in Javascript onAugust 17, 2017

前言

本文主要给大家介绍的关于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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
讲两件事:1.this指针的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件处理上的区别
Apr 12 Javascript
Extjs列表详细信息窗口新建后自动加载解决方法
Apr 02 Javascript
模拟select的代码
Oct 19 Javascript
使用Jquery来实现可以输入值的下拉选单 雏型
Dec 06 Javascript
jQuery拖拽 &amp; 弹出层 介绍与示例
Dec 27 Javascript
Javascript中常见的校验如域名、手机、邮箱等等
Jan 02 Javascript
JavaScript表格常用操作方法汇总
Apr 15 Javascript
JavaScript实现的encode64加密算法实例分析
Apr 15 Javascript
javascript基本语法
May 31 Javascript
laydate时间日历插件使用方法详解
Nov 14 Javascript
Vue + Element UI图片上传控件使用详解
Aug 20 Javascript
Vue-CLI 3 scp2自动部署项目至服务器的方法
Jul 24 Javascript
简单实现js进度条加载效果
Mar 25 #Javascript
你可能不知道的JSON.stringify()详解
Aug 17 #Javascript
vue组件Prop传递数据的实现示例
Aug 17 #Javascript
js实现随机点名小功能
Aug 17 #Javascript
浅谈Vuejs Prop基本用法
Aug 17 #Javascript
简单快速的实现js计算器功能
Aug 17 #Javascript
使用jquery的jsonp如何发起跨域请求及其原理详解
Aug 17 #jQuery
You might like
精致的人儿就要挑杯子喝咖啡
2021/03/03 冲泡冲煮
提问的智慧(2)
2006/10/09 PHP
php学习之变量的使用
2011/05/29 PHP
php中json_decode()和json_encode()的使用方法
2012/06/04 PHP
解析PHP中如何将数组变量写入文件
2013/06/06 PHP
PHP实现合并两个排序链表的方法
2018/01/19 PHP
PHP工厂模式的日常使用
2019/03/20 PHP
效率高的Javscript字符串替换函数的benchmark
2008/08/02 Javascript
让 JavaScript 轻松支持函数重载 (Part 2 - 实现)
2009/08/04 Javascript
JS实现图片预加载无需等待
2012/12/21 Javascript
Jquery获取复选框被选中值的简单方法
2013/07/04 Javascript
jquery实现加载等待效果示例
2013/09/25 Javascript
jquerymobile局部渲染的各种刷新方法小结
2014/03/05 Javascript
jQuery中:first选择器用法实例
2014/12/30 Javascript
js实现同一页面多个不同运动效果的方法
2015/04/10 Javascript
JavaScript动态提示输入框输入字数的方法
2015/07/27 Javascript
jQuery动态添加可拖动元素完整实例(附demo源码下载)
2016/06/21 Javascript
用vue的双向绑定简单实现一个todo-list的示例代码
2017/08/03 Javascript
webpack 1.x升级过程中的踩坑总结大全
2017/08/09 Javascript
使用express+multer实现node中的图片上传功能
2018/02/02 Javascript
基于jQuery.i18n实现web前端的国际化
2018/05/04 jQuery
element ui分页多选,翻页记忆的实例
2019/09/03 Javascript
微信小程序实现多行文字超出部分省略号显示功能
2019/10/23 Javascript
Python实现比较扑克牌大小程序代码示例
2017/12/06 Python
python清除函数占用的内存方法
2018/06/25 Python
解决tensorflow模型参数保存和加载的问题
2018/07/26 Python
python+selenium+chromedriver实现爬虫示例代码
2020/04/10 Python
Python 实现国产SM3加密算法的示例代码
2020/09/21 Python
使用C#编写创建一个线程的代码
2013/01/22 面试题
工地安全生产标语
2014/06/06 职场文书
餐饮店长岗位职责
2015/04/14 职场文书
大学推普周活动总结
2015/05/07 职场文书
电影小兵张嘎观后感
2015/06/03 职场文书
python实现简单的聊天小程序
2021/07/07 Python
python中super()函数的理解与基本使用
2021/08/30 Python
Java多线程并发FutureTask使用详解
2022/06/28 Java/Android