JavaScript 对象 : Using Arguments as object property

标签 javascript arrays object arguments coercion

我正在使用 Arguments 对象重新实现 memoize 函数。我想知道为什么这会起作用。例如,传入2个参数:

var args = Array.prototype.slice.call(arguments); // input: 1,2

然后我会将 args 数组存储到一个对象中。例如,

var obj = {};
    obj[args] = 2;

如果您要调用 Object,您会看到以下内容:

{ 1,2: 2 }/*shows as this*/  { [1,2]: 2 }/*but not as this*/

并不是说我想要第二个对象,只是好奇幕后发生了什么。这就是所谓的 Javascript 强制转换吗?

最佳答案

对象属性名称始终是字符串。所以当你这样做时:

obj[args] = 2;

它将其视为

obj[args.toString()] = 2;

而数组的toString()方法相当于.join(","),所以上面等价于:

obj[args.join(",")] = 2;

与您看到的结果相符。

关于JavaScript 对象 : Using Arguments as object property,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34621877/

相关文章:

JavaScript 使用 splice() 对数组进行排序,结果为 NaN

javascript - Angular,折扣过滤器 - 将变量传递到过滤器中?

php - 如何从数组中去除只有空白的元素?

java - 将数组从 Jsp 传递到操作类

javascript - 从三个数组创建对象

javascript - 在 JavaScript 对象中按值查找

javascript - 在函数中调用函数时处理参数的最佳方式

javascript - underscore/lodash - 组合具有相同元素的对象

.NET 排序列表 <> 与关联数组

swift - 3d 对象导航器和移动