Proxy代理实现对象关键属性无法更改
由于js的语言特性对象可以动态增加和修改属性和方法,但代码很多时可能会不小心覆盖前面对象的一些关键属性和方法,导致结果异常,且不方便查找出错的地方。利用es6的proxy可以简单实现对象某些关键属性的私有化,不改变其他属性方法的覆盖与扩展。
function signal(obj, arr) {
return new Proxy(obj, {
set(target, key, value) {
if (arr.indexOf(key) !== -1 && target.hasOwnProperty(key)) {
throw Error(`私有属性${key}不可更改`);
return;
}
target[key] = value
}
})
}
方法接收两个参数,第一个为需要代理的对象,第二个为需要定义为私有化的属性方法数组。调用示例:
const stu = signal({
name: '小',
age: '18'
}, ['name', 'age'])
//
let obj = {
name: 'user',
age: '18'
}
const per = signal(obj, ['name', 'age'])
当我们试图修改定义为私有属性的值时


本文介绍如何使用ES6的Proxy特性来保护对象的关键属性不受修改,防止因属性覆盖导致的错误,同时保持对象的灵活性。通过具体示例展示如何设定私有属性。
1467

被折叠的 条评论
为什么被折叠?



