ES6 proxy代理与 setter,getter方法的区别

setter 当获取指定属性时调用

getter获取指定属性时调用

 let ownProp = {
        _name: '鸡桑',
        age: '两年半',
        set name(value) {
            console.log('修改了名字');
            this._name = value;
        },
        //名字不能与setter,getter里的一致
        get name() {
            console.log('获取了名字');
            return this._name;
        }
    }

proxy代理,对目标调用属性方法等都会触发

 let managerId = ['020609']; //设立一个管理员id库
 let handler = {//设立一个处理方式
        get: function (target, key) {//获取属性时触发
            return target[key];//返回目标值
        },
        set: function (target, key, value) {//设置属性时触发
            let id = prompt('请输入你的管理员ID');  //输入id
            //判断输入的id是否为管理员id   正确触发修改       不符合触发弹窗
            managerId.includes(id) ? target[key] = value : alert('仅限管理员修改')
        }
    };
//                 这个传给target 这个传给key
let proxy = new Proxy(ownProp, handler);
let proxy2 = new Proxy(ownProp, handler);
proxy.name = '鸡哥';  //代理修改
console.log(proxy.name); 

setter与getter以及porxy代理都能监听属性方法的修改与获取,不过setter与getter仅限指定的属性

proxy监听全部,并且两者并不冲突,可以多重监听;一定程度上保证安全性;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值