handler.set() 方法用于拦截设置属性值的操作
var p = new Proxy(target, {
set: function(target, property, value, receiver) {
}
});
以下是传递给set方法的参数,this上下文绑定在handler对象上.
targetpropertyvaluereceiverobj.name = "jen",obj不是一个proxy且自身不含name属性,但它的原型链上有一个proxy,那么那个proxy的set拦截函数会被调用,此时obj会作为receiver参数传进来。set方法应该返回一个布尔值,返回true代表此次设置属性成功了,如果返回false且设置属性操作发生在严格模式下,那么会抛出一个TypeError。
handler.set 方法用于拦截设置属性值的操作。
该方法会拦截目标对象的以下操作:
proxy[foo] = bar 和 proxy.foo = barObject.create(proxy)[foo] = barReflect.set()如果违背以下的约束条件,proxy会抛出一个TypeError:
TypeError 异常。以下代码演示如何捕获属性的设置操作。
var p = new Proxy({}, {
set: function(target, prop, value, receiver) {
console.log("called: " + prop + " = " + value);
return true;
}
});
p.a = 10; // "called: a = 10"
| Specification | Status | Comment |
|---|---|---|
| ECMAScript 2015 (6th Edition, ECMA-262) [[Set]] |
Standard | Initial definition. |
| ECMAScript Latest Draft (ECMA-262) [[Set]] |
Draft |
| Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
|---|---|---|---|---|---|
| Basic support | ? | 18 (18) | ? | ? | ? |
| Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
|---|---|---|---|---|---|---|
| Basic support | ? | ? | 18.0 (18) | ? | ? | ? |