Proxy代理(ES6)

ES6中的Proxy提供了强大的对象代理功能,能够自定义对象的读取、赋值、枚举、函数调用等行为。Proxy的基本语法是`let p = new Proxy(target, handler)`,其中target是待代理的对象,handler则定义了各种拦截操作的处理方式。常见的拦截操作包括get、set、has、ownKeys、deleteProperty、apply和construct。" 102871002,8058541,MATLAB 2015与2019读取bmp图像差异,"['MATLAB', '图像处理', '版本更新', '函数行为', 'bmp格式']
摘要由CSDN通过智能技术生成

Proxy

在 ES6 标准中新增的一个非常强大的功能是 Proxy,它可以自定义一些常用行为如查找、赋值、枚举、函数调用等。通过 Proxy 这个名称也可以看出来它包含了“代理”的含义,只要有“代理”的诉求都可以考虑使用 Proxy 来实现。

基本语法

语法

let p = new Proxy(target, handler)

解释

在这里插入图片描述
MDN 给出的解释偏官方,通俗的讲第一个参数 target 就是用来代理的“对象”,被代理之后它是不能直接被访问的,而 handler 就是实现代理的过程。

常用拦截操作

get

拦截对象属性的读取,比如proxy.foo和proxy[‘foo’]。

let arr = [7, 8, 9]
arr = new Proxy(arr, {
   
    get(target, prop) {
   
        // console.log(target, prop)
        return prop in target ? target[prop] : 'error'
    }
})
console.log(arr[1])
console.log(arr[10])
let dict = {
   
    'hello': '你好',
    'world': '世界'
}
dict = new Proxy(dict, {
   
    get(target, prop) {
   
        return prop in target ? target[prop] : prop
    }
})
console.log(dict['world'])
console.log(dict['imooc'])

set

拦截对象属性的设置,比如proxy.foo = v或proxy[‘foo’] = v,返回一个布尔值。

let arr = []
arr = new Proxy(arr, {
   
    set(target, prop, val) {
   
        if (typeof val === 'number') {
   
            target[prop] = val
            
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值