es6 proxy代理
es6 新增构造函数 Proxy
Proxy 构造函数,可以使用new 去创建,可以往里面插入两个参数,都是对象
let target = {}
let handler = {}
let proxy = new Proxy(target,handler);
proxy.a = 'b'
console.log(proxy.a) //b
上面代理拦截的操作handler 是个空对象所有不产生任何影响,target 代表时需要代理的哪个对象
Proxy 一共可以代理拦截对象的13种操作
1. get 当读取对象属性时触发 get 拦截一共可以传入三个参数 get(target,key,receiver) target 代表当前对象,key 当前属性名
receiver 一般用不上,代表的是Proxy 对象
//常见的对象 get操作 代理
var handler = {
get (target,key,receiver) {
console.log(key);
return `您想要的值是${target[key]}`
}
}
var proxyy=new Proxy({},handler);
proxyy.xx=;
console.log(proxyy.xx); //xx 您想要的值是90 //如果一个对象属性不可配置 且不可写,则不能使用proxy 访问此属性
var definedObject = Object.defineProperty({},'name',{
writable:false,// 属性是否科协
configurable:false,// 是否可重新配置
value:'czcz' // 默认值
})
var prox = new Proxy(definedObject,handler);
prox.name;
//proxy.js:23 Uncaught TypeError: 'get' on proxy:
//property 'name' is a read-only and non-configurable data property
//on the proxy target but the proxy did not return its actual
//value (expected 'czcz' but got '您想要的值是czcz')
2.set set拦截一共可以传入四个参数 (target,key,value,receiver) 前三个参数必传,最后一个参数可选,以此代表,对象
属性名,设置的属性值,Proxy 对象
// proxy 的set 方法,使用了set 一定要对target[key] 赋值要不会返回undefined
// 如下要是if条件过后 没有 target[key] = value 则 proz.age 最终会是undefined
var sethandler = {
set (target,key,value,receiver) {
if(key == 'name') {
target[key] = `魔人的小妖精${value}`
return
}
target[key] = value
}
}
var proz = new Proxy({},sethandler);
proz.name = 'ljkkk';
proz.age = '';
console.log(proz.name,proz.age) //魔人的小妖精ljkkk 18 //如果对象的属性描述是不可写,则不能使用proxy set 方法
var objsetfalse = Object.defineProperty({},'name',{
value:'czcz',
writable:false
}) var proc = new Proxy(objsetfalse,sethandler);
proc.name = 'lklk';
console.log(proc.name) //输出'czcz' 说明sethandler 里面的set操作无用
3.apply 拦截对象的apply和call,和函数的调用 , apply一共可以传入三个参数 ,apply(target,ctx,args) ,目标对象,目标对象的上下文对象,参数数组
//apply 拦截函数的调用
var applyhandler = {
apply (target,ctx,args) {
console.log('apply',ctx,args)
}
}
var fn = function () {
console.log('xxccc');
}
var prolk = new Proxy(fn,applyhandler);
prolk(); // apply undefined []
//拦截 apply or call 操作
prolk.apply({},[,,]); //apply {} (3) [1, 3, 4]
prolk.call(null,,,); //apply null (3) [1, 3, 5]
4.has 拦截hasProperty 操作判断对象是否具有某个属性是生效,has(target,key) 方法值传入连个参数, has 只有执行in 操
作时生效,但执行 for in 不生效(注如果某个属性不可配置或者该对象不可扩展则不能使用has拦截)
//has 属性的拦截
var hashandler = {
has (target,key) {
if(key === 'name') {
return false
}
return true
}
}
var prohas = new Proxy({},hashandler);
prohas.age = ''
prohas.name = 'zc'
console.log('name' in prohas) //false
console.log('age' in prohas) // true
5.construct 当使用new 去创建一个对象时进行拦截 construct(target,args,newtarget) 当前对象,参数,实例对象
var conhandler = {
construct (target,args,newtarget) {
console.log(target.args,newtarget)
return new target(...args)
}
}
var pp = new Proxy(function () {},conhandler)
new pp('',''); //undefined ƒ () { [native code] }
//传入的一定要是个构造函数
es6 proxy代理的更多相关文章
- 新的知识点来了-ES6 Proxy代理 和 去银行存款有什么关系?
ES给开发者提供了一个新特性:Proxy,就是代理的意思.也就是我们这一节要介绍的知识点. 以前,ATM还没有那么流行的时候(暴露年纪),我们去银行存款或者取款的时候,需要在柜台前排队,等柜台工作人员 ...
- ES6 proxy代理详解及用法
proxy官方的详细解释为代理器,个人理解为相当于一个拦截器,外部的所有访问必须先通过这层拦截,监视到对象的读写过程,因此提供了这 种机制对外部的访问进行过滤和修改. 上述例子为proxy new一个 ...
- ES6 proxy(代理拦截) &&Reflect
- ES6新特性:Proxy代理器
ES6新特性:Proxy: 要使用的话, 直接在浏览器中执行即可, node和babel目前还没有Proxy的polyfill;,要使用的话,直接在浏览器中运行就好了, 浏览器的兼容性为:chrome ...
- 详解es6中Proxy代理对象的作用
在es6中新添加了Proxy,那么它有什么作用啊?Proxy本意为代理,而es6中的Proxy也就是代理对象,那么代理对象感觉听起来很模糊,在这里就解释一下Proxy代理对象的作用. Proxy的主要 ...
- es6 Proxy对象详解
Proxy用于修改某些操作的默认行为,也可以理解为在目标对象之前架设一层拦截,外部所有的访问都必须先通过这层拦截,因此提供了一种机制,可以对外部的访问进行过滤和修改.这个词的原理为代理,在这里可以表示 ...
- ES6 Proxy 性能之我见
ES6 Proxy 性能之我见 本文翻译自https://thecodebarbarian.com/thoughts-on-es6-proxies-performance Proxy是ES6的一个强力 ...
- Vue3.0 响应式数据原理:ES6 Proxy
Vue3.0 开始用 Proxy 代替 Object.defineProperty了,这篇文章结合实例教你如何使用Proxy 本篇文章同时收录[前端知识点]中,链接直达 阅读本文您将收获 JavaSc ...
- C++设计模式-Proxy代理模式
Proxy代理模式 作用:为其他对象提供一种代理以控制对这个对象的访问. 代理的种类: 如果按照使用目的来划分,代理有以下几种: 远程(Remote)代理:为一个位于不同的地址空间的对象提供一个局域代 ...
随机推荐
- SpringBoot之旅第二篇-配置
一.引言 虽然springboot帮我们进行了自动配置,但配置还是不可避免的,比如最简单的端口号,数据库连接.但springboot的配置一般不用xml进行配置,而是yml和properties,选择 ...
- FreeSql 新查询功能介绍
FreeSql FreeSql 是一个功能强大的 NETStandard 库,用于对象关系映射程序(O/RM),提供了 CodeFirst/DbFirst/CURD/表达式函数/读写分离 等基础封装. ...
- RabbitMQ死信队列另类用法之复合死信
前言 在业务开发过程中,我们常常需要做一些定时任务,这些任务一般用来做监控或者清理任务,比如在订单的业务场景中,用户在创建订单后一段时间内,没有完成支付,系统将自动取消该订单,并将库存返回到商品中,又 ...
- pins-模块内的代码及资源隔离方案
随着项目的不断迭代,复杂的业务模块及项目自身的基础技术组件迅速扩张,以往基于单个模块的项目往往显得过于臃肿.代码目录结构,包名混乱,代码模块职责不清晰,耦合度高,不便维护.基础公共组件没有抽取并剥离干 ...
- iftop命令使用范例
iftop 介绍 iftop是一款实时流量监控工具,监控TCP/IP连接等,缺点就是无报表功能.必须以root身份才能运行. 实例 默认是监控第一块网卡的流量 iftop 监控eth1 iftop - ...
- centos7 ambari安装HDP
环境介绍:操作系统为Centos7.1:测试设备全部为内网设备,不通公网,所以需要配置本地yum源: 首先安装ansible工具,用来批量安装ambari.java以及基础的一些配置: 一. 免密钥登 ...
- ng6.1 新特性:滚回到之前的位置
在之前的版本中滚动条位置是一个大问题,主要表现在 1. 使用快捷键或者手势前进/后退的时候,滚动条的位置经常是错乱的,所以只能每个页面都要重置一个滚动条的位置: 2. #anchor1 锚点位置无法定 ...
- 微信小程序 写一个获取验证码 及setInterval 使用基本方法
<!--index.wxml--> <view class="container"> <view class="container_cont ...
- 零基础如何自学java开发?
开篇直奔主题,java 学习个人感觉分为两种途径,第一种是在学校,在培训机构等地方学习. 有人指导:第二种是自学,通过视频,书籍,朋友等完成学习. 本文适合 自学,且基础薄弱或者无基础的人.先介绍下我 ...
- .NET Core TDD 前传: 编写易于测试的代码 -- 单一职责
第1篇: 讲述了如何创造"缝". "缝"(seam)是需要知道的概念. 第2篇, 避免在构建对象时写出不易测试的代码. 第3篇, 依赖项和迪米特法则. 第4篇 ...