gpt4 book ai didi

javascript - ES6 Proxy 返回值中的 handler.set

转载 作者:行者123 更新时间:2023-11-30 09:41:45 25 4
gpt4 key购买 nike

在这段代码中

function report(message) {
console.log(message);
}
function makeLoggable(target) {
return new Proxy(target, {
get(target, property) {
report(`Reading ${property}`);
const param = target;
return param[property];
},
set(target, property, value) {
report(`Writing value ${value} to ${property}`);
const param = target;
return param[property] = value;
},
});
}
let ninja = { name: 'Jack' };
ninja = makeLoggable(ninja);
console.assert(ninja.name === 'Jack', 'Our ninja Jack');
ninja.status = '';

我有两个问题:

  1. 如果我在最后一行将属性状态设置为 0 或“”(空字符串),为什么会出现错误?

Uncaught TypeError: 'set' on proxy: trap returned falsish for property 'status'(…)

  1. 在规范中它说我应该返回一个 bool 值。但就我而言,在 set() 方法中我不返回任何 bool 值。在那种情况下,为什么这段代码有效?

最佳答案

你得到一个 TypeError 因为 "" 是假的。如果您尝试将属性值设置为 0false,您将收到相同的错误。

作为MDN states

In strict mode, a false return value from the set handler will throw a TypeError exception.

MDN 在这里有些不清楚,因为似乎任何虚假值(不仅仅是 false)都会导致设置处理程序抛出 TypeError。

您的代码适用于大多数情况,因为您返回的是赋值结果。 ninja.test = 'string' 将返回真实的 string

为了解决这个问题,只需将您的设置函数更改为以下内容:

set(target, property, value) {
report(`Writing value ${value} to ${property}`);
const param = target;
param[property] = value;
return true;
}

关于javascript - ES6 Proxy 返回值中的 handler.set,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40852491/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com