最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Javascript中getter和setter基本介绍

来源:动视网 责编:小采 时间:2020-11-27 20:14:14
文档

Javascript中getter和setter基本介绍

Javascript中getter和setter基本介绍:最近在工作中遇到了getter和setter,getter 是一种获得属性值的方法,setter是一种设置属性值的方法。下面这篇文章主要给大家介绍了关于Javascript中getter和setter的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。前言本文主要给大家介绍的关于Ja
推荐度:
导读Javascript中getter和setter基本介绍:最近在工作中遇到了getter和setter,getter 是一种获得属性值的方法,setter是一种设置属性值的方法。下面这篇文章主要给大家介绍了关于Javascript中getter和setter的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。前言本文主要给大家介绍的关于Ja


最近在工作中遇到了getter和setter,getter 是一种获得属性值的方法,setter是一种设置属性值的方法。下面这篇文章主要给大家介绍了关于Javascript中getter和setter的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。

前言

本文主要给大家介绍的关于Javascript中getter和setter的相关内容,第一次听说这个东西的时候是vue.js里面的数据绑定,只要绑定了数据,修改对象属性可以自动反馈到dom上,很神奇,后面也看到了文档里面实现是对对象定义了getter和setter并覆盖原属性,索性就来总结这两者的用法,下面话不多说了,来一起看看详细的介绍吧。

原理

利用Object.defineProperty来重写对象属性为getter和setter,通过getter和setter顺便改变绑定DOM节点的值

例子

摘自MDN

利用这个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基本介绍

Javascript中getter和setter基本介绍:最近在工作中遇到了getter和setter,getter 是一种获得属性值的方法,setter是一种设置属性值的方法。下面这篇文章主要给大家介绍了关于Javascript中getter和setter的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。前言本文主要给大家介绍的关于Ja
推荐度:
标签: 介绍 js javascript
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top