我如何使 `foo[1] ==1; foo[1][2]==3; foo[1][2][3]==6` 在 JavaScript 工作?

How do I make `foo[1] ==1; foo[1][2]==3; foo[1][2][3]==6` work in JavaScript?

如何定义 foo 以使以下代码按预期正确工作(在 JavaScript 中)?

foo[1] + 1             // 2
foo[1][2] + 1          // 4
foo[10][20][30] + 1    // 61
foo[100][200][300] + 1 // 601

这是我遇到过的一道面试题

这听起来像是旧 variadic chainable sum function puzzle, with proxy member access instead of function calls. The possible approaches 的新版本,但仍然是一样的,…+1 表明他们正在寻找 valueOf 解决方案。同样,foo+1 将是 1+foo/Number(foo) 将是 0.

const handler = {
    get(target, propName, receiver) {
        if (typeof propName == 'string' && /^\d+$/.test(propName))
            return sumProxy(target + parseInt(propName, 10));
        else
            return Reflect.get(target, propName, receiver);
    }
};
function sumProxy(value) {
    return new Proxy({
        valueOf() { return value; }
    }, handler);
}
const foo = sumProxy(0);

console.log(foo + 1);                // 1
console.log(foo[1] + 1);             // 2
console.log(foo[1][2] + 1);          // 4
console.log(foo[10][20][30] + 1);    // 61
console.log(foo[100][200][300] + 1); // 601