es6 Proxy简单使用
es6的Proxy是什么?
可以理解为,是在访问对象前的一层拦截。只要访问的该对象,就要通过这个一层拦截。这一层的拦截,可以进行数据的过滤和更改
比如下面这个
var p = new Proxy({},{
    get:function(){
        return '没有这个属性'
    }
})
p.name = '张三'
p.age    // "没有这个属性"
p.name //张三
上面的内容说,在读取p里的属性的时候,如果不存在返回 '没有这个属性'
它有很多种截取属性。
- get(target, propKey, receiver):拦截对象属性的读取,比如proxy.foo和proxy['foo']。
- set(target, propKey, value, receiver):拦截对象属性的设置,比如proxy.foo = v或proxy['foo'] = v,返回一个布尔值。
- has(target, propKey):拦截propKey in proxy的操作,返回一个布尔值。
- deleteProperty(target, propKey):拦截delete proxy[propKey]的操作,返回一个布尔值。
- ownKeys(target):拦截Object.getOwnPropertyNames(proxy)、Object.getOwnPropertySymbols(proxy)、Object.keys(proxy)、for...in循环,返回一个数组。该方法返回目标对象所有自身的属性的属性名,而Object.keys()的返回结果仅包括目标对象自身的可遍历属性。
- getOwnPropertyDescriptor(target, propKey):拦截Object.getOwnPropertyDescriptor(proxy, propKey),返回属性的描述对象。
- defineProperty(target, propKey, propDesc):拦截Object.defineProperty(proxy, propKey, propDesc)、Object.defineProperties(proxy, propDescs),返回一个布尔值。
- preventExtensions(target):拦截Object.preventExtensions(proxy),返回一个布尔值。
- getPrototypeOf(target):拦截Object.getPrototypeOf(proxy),返回一个对象。
- isExtensible(target):拦截Object.isExtensible(proxy),返回一个布尔值。
- setPrototypeOf(target, proto):拦截Object.setPrototypeOf(proxy, proto),返回一个布尔值。如果目标对象是函数,那么还有两种额外操作可以拦截。
- apply(target, object, args):拦截 Proxy 实例作为函数调用的操作,比如proxy(...args)、proxy.call(object, ...args)、proxy.apply(...)。
- construct(target, args):拦截 Proxy 实例作为构造函数调用的操作,比如new proxy(...args)。
第一种:
get
get这个方法接收三个参数。第一个为操作对象,第二个是属性名,第三个是proxy实例本身。第三个参数不是必填参数
var tar = {
    name:"lly"
}
var pro = new Proxy(tar,{
    get:function(target,propkey){
           if(propkey in target){
                return target[propkey]
           }else{
                throw new RangeError("你错的也太狠了")
            }
    }
})
pro.name // lly
pro.age  // RangeError: 你错的也太狠了
上面的内容说道,访问的对象不存在的话,抛出一个错误
第二种
set
这个方法,接收四个参数 访问对象、访问属性、访问的属性值、proxy实例对象
这次例子我们换一个写法,让我们熟悉更多写法 我们来看下面这个例子
var handel = {
    set:function(obj,prop,value){
        if(prop === 'age'){
              if(value > ){
                    throw new RangeError("你是老妖怪吧")
            }
        }
    }
}
var p = new Proxy({},handel);
p.age =    //抛出一个错误     RangeError: 你是老妖怪吧
这个set可以拦截访问对象要添加的值。如果值不符合拦截器的规则,就会抛出错误。
第三种
apply
apply方法拦截函数的调用、call和apply操作。
方法接收三个参数 目标对象、目标对象的上下文对象(this)和目标对象的参数数组。
我们看下面这个例子
function d(){
    return "曾沛慈"
}
var p = new Proxy(d,{
    apply:function(){
        return "可乐"
    }
})
p();    //可乐
上面代码中,变量p是 Proxy 的实例,当它作为函数调用时(p()),就会被apply方法拦截,返回一个字符串。
var handel = {
    has(target,key){
        if(key[] == "_"){
               return false
         }
        return key in target;
    }
}
var obj = {_name:'lly',name:"cyd"}
var p = new Proxy(obj,handel);
'_name' in p
//false
es6 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 ... 
- ES6 Proxy和Reflect(下)
		construct() construct方法用于拦截new命令. var handler = { construct (target, args) { return new target(...ar ... 
- ES6 Proxy和Reflect (上)
		Proxy概述 Proxy用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种"元编程"(meta programming),即对编程语言进行编程. Proxy可以理 ... 
- es6 proxy代理
		es6 新增构造函数 Proxy Proxy 构造函数,可以使用new 去创建,可以往里面插入两个参数,都是对象 let target = {} let handler = {} let proxy ... 
- es6 Proxy
		proxy在语言层面去操作一个对象 var user={}; user.fname='Bob'; user.lname="Wood"; user.fullName= functio ... 
- ES6 Proxy的应用场景
		一.相关API Proxy Reflect 二.Proxy应用场景 1.数据校验 表单提交的时候做数据校验,例如年龄是不是满足条件,数据类型是不是满足要求等等,这场场景非常适合使用Proxy. 下面展 ... 
- es6 很简单
		es6出了许多好的,优秀的特性.下面列举一些常用的 其实这些特性都很好理解,一两句话就可以表达出来看.主要是对旧的写法的一种改进. function 加了一些语言糖,传参更方便 class ... 
- es6 Proxy对象详解
		Proxy用于修改某些操作的默认行为,也可以理解为在目标对象之前架设一层拦截,外部所有的访问都必须先通过这层拦截,因此提供了一种机制,可以对外部的访问进行过滤和修改.这个词的原理为代理,在这里可以表示 ... 
随机推荐
- activity的四种启动模式详细分析
			1.android中通过任务队列来管理activity 采用栈的结构就是后进先出 手机里面如果启动多个应用就会启动多个任务栈来管理对应的activity. 主要解决下面的问题:对应的四种启动模式: 1 ... 
- Ueditor富文本添加视频内容,视频不显示以及编辑富文本时,视频不显示解决方案
			问题是在添加视频时,编辑器会把视频标签<video>换成<img>.很讨厌... 1.2是解决添加视频时不显示,3是解决编辑时不显示 ueditor.all.js文件中 第7 ... 
- [转]理解神经网络:从神经元到RNN、CNN、深度学习
			神经网络是目前最流行的机器学习算法之一.随着时间的推移,证明了神经网络在精度和速度方面,比其他的算法性能更好.并且形成了很多种类,像CNN(卷积神经网络),RNN,自编码,深度学习等等.神经网络对于数 ... 
- 计算机网络之DNS协议
			DNS( Domain Name System)是“域名系统”的英文缩写,是一种组织成域层次结构的计算机和网络服务命名系统,它用于TCP/IP网络,它所提供的服务是用来将主机名和域名转换为IP地址的工 ... 
- SQL注入之常用工具sqlmap
			通常来说,验证一个页面是否存在注入漏洞比较简单,而要获取数据,扩大权限,则要输入很复杂的SQL语句,有时候我们还会对大量的URL进行测试,这时就需要用到工具来帮助我们进行注入了. 目前流行的注入工具有 ... 
- 锐捷交换机18010-X端口假死现象
			一次上架锐捷交换机,由于ODF光衰不稳定,导致交换机端口down,排查很多发现以下故障: 重置18010-X端口发现提示一下命令: Port in violation! Use 'errdisable ... 
- zabbix4.4安装
			本安装操作系统为centos7.5. 安装前准备: 1.1 安装依赖包: yum -y install wget net-snmp-devel OpenIPMI-devel httpd openssl ... 
- 什么才是市场急需的前端工程师?要价1.8W,HR不敢还嘴!
			据统计,国外的前端开发人员和后端开发人员比例约1:1,但是在国内比例却在1:3以下, Web前端开发职位人才缺口巨大.前端工程师的发展之路十分有“钱”景. 每天,HR 群都有人在吐槽招不到前端工程师. ... 
- 看球的巴士——线性dp
			[题目描述] 两个球队的支持者要一起坐车去看球,他们已经排成了一列.我们要让他们分乘若干辆巴士,同一辆巴士上的人必须在队伍中是连续的.为了在车上不起冲突,希望两队的支持者人数尽量相等,差至多是D.有一 ... 
- nodejs 获取当前路径的方法
			var path = require("path"); var url = path.resolve('./'); 
