一篇文章搞懂JavaScript中的代理和代理的使用

 更新时间:2021年08月26日 16:47:01   作者:CSDN  
这篇文章主要为大家详细介绍了JavaScript代理和代理的使用的方法,感兴趣的小伙伴们可以参考一下,希望能给你带来帮助

什么是代理

MDN上的定义:Proxy(也就是代理) 对象用于定义基本操作的自定义行为(如属性查找,赋值,枚举,函数调用等)。

官方的定义总是这么晦涩枯燥,那么究竟Proxy能做什么?

1.代理这个概念来自于元编程,就是一种你可以编写出一个可以读取、修改、分析、甚至生成新程序的程序。而JS可以通过Proxy和Reflect这两个对象来进行js元编程!!

2.Proxy就是代理,当我们不方便去访问某个对象或者不满足于简单的访问时,代理就可以作为“中间人”来帮助我们更好的来控制对象的操作!!

Proxy的基本知识

语法:

const handler = {};
let target = {};//目标对象
let userProxy = new Proxy(target,handler);//成功实现代理!!
userProxy.a = 1;
console.log(target.a);//1
console.log(target == userProxy);//false

target: 要使用 Proxy 包装的目标对象

handler: 一个通常以函数作为属性的对象,各属性中的函数分别定义了在执行各种操作时代理的行为。

OK!那么恭喜你,你已经掌握了Proxy的定义。

在使用中,需要我们去更多费神的是handler中代理行为的代码,它可以帮助我们来更好的使用Proxy

handler对象方法

const handler = {
	get(target,prop,receiver){
		console.log('get!');
		return 'a';
	}
}
let target = {name:'tar'};
let userProxy = new Proxy(target,handler);
userProxy.name

当然还有其他更多的方法请参考MDN:handler 对象的方法

Proxy可以实现的

跟踪属性访问

当我们需要知道对象什么时候被访问、修改时。

 let target = {
	name:'ww'
	}
 const handlers = {
    get(tar, prop){
     	console.log('get');
     	return Reflect.get(...arguments); 
     },
     set(tar,prop){
		console.log('set');
		return Reflect.set(...arguments);
	 }
  }
  let userProxy = new Proxy(target, handlers);
  userProxy.name;
  userProxy.name = 'wqw';

解决对象属性为undefined的问题

let target = {}
  let handlers = {
    get: (target, property) => {
      target[property] = (property in target) ? target[property] : {}
      if (typeof target[property] === 'object') {
        return new Proxy(target[property], handlers)
      }
      return target[property]
    }
  }
  let proxy = new Proxy(target, handlers)
  console.log('z' in proxy.x.y) // false (其实这一步已经针对`target`创建了一个x.y的属性)
  proxy.x.y.z = 'hello'
  console.log('z' in proxy.x.y) // true
  console.log(target.x.y.z)     // hello

我们代理了get,并在里边进行逻辑处理,如果我们要进行get的值来自一个不存在的key,则我们会在target中创建对应个这个key,然后返回一个针对这个key的代理对象。

这样就能够保证我们的取值操作一定不会抛出can not get xxx from undefined

但是这会有一个小缺点,就是如果你确实要判断这个key是否存在只能够通过in操作符来判断,而不能够直接通过get来判断。

参考资料:

MDN-Proxy

JS-设计模式

Proxy可以做哪些有趣的事情

元编程

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • JavaScript DOM事件(笔记)

    JavaScript DOM事件(笔记)

    这篇文章主要介绍了JavaScript DOM事件(笔记) ,需要的朋友可以参考下
    2015-04-04
  • HTML文档引入JS模块出现路径问题解决办法

    HTML文档引入JS模块出现路径问题解决办法

    这篇文章主要给大家介绍了关于HTML文档引入JS模块出现路径问题的解决办法,在HTML中引入JavaScript模块时如果遇到路径问题,通常是因为模块的引用路径不正确,本文将解决办法介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • 轻松实现js弹框显示选项

    轻松实现js弹框显示选项

    这篇文章主要为大家详细介绍了js轻松实现弹框显示选项效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • javascript设计模式之模块模式学习笔记

    javascript设计模式之模块模式学习笔记

    这篇文章主要为大家详细介绍了javascript设计模式之模块模式学习笔记,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • js实现图片上传并预览功能

    js实现图片上传并预览功能

    这篇文章主要为大家详细介绍了js实现图片上传并预览功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • JavaScript对象_动力节点Java学院整理

    JavaScript对象_动力节点Java学院整理

    这篇文章主要为大家详细介绍了JavaScript对象的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • JavaScript中常见的七种继承及实现

    JavaScript中常见的七种继承及实现

    JS的继承方式在我们面试的时候经常会被问到,所以深入理解js继承方式以及它们的优缺点是非常有必要的。本文为大家整理了JavaScript中常见的七种继承及实现,需要的可以参考一下
    2023-03-03
  • 有关suggest快速删除后仍然出现下拉列表的bug问题

    有关suggest快速删除后仍然出现下拉列表的bug问题

    写suggest的时候,有时我们快速删除输入框的文字后,但是suggest下拉列表还有出现,导致的原因是因为ajax异步请求造成的,下面通过本文给大家分享下解决方法,感兴趣的朋友一起看看
    2016-12-12
  • JavaScript 微任务和宏任务讲解

    JavaScript 微任务和宏任务讲解

    这篇文章主要分享了JavaScript 微任务和宏任务讲解,在js中,我们一般将所有的任务都分成两类,一种是同步任务,另外一种是异步任务。而在异步任务中,又有着更加细致的分类,那就是微任务和宏任务,下面来一起学习js中的微任务和宏任务吧
    2021-12-12
  • JavaScript截取指定长度字符串点击可以展开全部代码

    JavaScript截取指定长度字符串点击可以展开全部代码

    这篇文章主要介绍了JavaScript截取指定长度字符串点击可以展开全部代码 的相关资料,需要的朋友可以参考下
    2015-12-12

最新评论