初始化对象时,javascript 属性 名称中的双方括号有什么意义?
What is the significance of double square brackets in javascript property names when initializing the object?
我目前正在查看不久前编写的一些代码,我不确定为什么以下 2 个语句相同,出于某种原因我选择了第一种方式。
const a = 'foo';
const b = { [[a]]: 'boo' } // This is in code
const c = { [a]: 'boo' } // ES6 way
它们似乎都产生了完全相同的结果。我不确定第一个选项是否是 ES6 之前的有效选项,但是当我在节点 0.10 上尝试时,例如它没有将它们中的任何一个识别为有效语句。了解为什么双方括号会产生相同的结果会很有帮助。
更新:
看到comments/answer后,我尝试确认双方括号内的表达式是否被视为数组,确实如此。
> const foo = 'foo'
undefined
> const boo = 'boo'
undefined
> const combo = { [foo,boo]: 'foo boo' }
const combo = { [foo,boo]: 'foo boo' } // This doesn't work foo,boo is not a valid expression
^
Uncaught SyntaxError: Unexpected token ','
> const combo = { [[foo,boo]]: 'foo boo' }
undefined
> combo
{ 'foo,boo': 'foo boo' } // Treats expression itself as array and `toString()` gets called on the array producing 'foo,boo' string
在ES6中,[expression]: value
解释如下:
- 评价
expression
- 将结果转换为字符串
- 使用这个字符串作为键
分别是
given [ [a] ]: 'boo'
evaluate [a] => ['foo']
String ['foo'] => 'foo'
result => {'foo': 'boo'}
换句话说,多余的括号将被忽略。
我目前正在查看不久前编写的一些代码,我不确定为什么以下 2 个语句相同,出于某种原因我选择了第一种方式。
const a = 'foo';
const b = { [[a]]: 'boo' } // This is in code
const c = { [a]: 'boo' } // ES6 way
它们似乎都产生了完全相同的结果。我不确定第一个选项是否是 ES6 之前的有效选项,但是当我在节点 0.10 上尝试时,例如它没有将它们中的任何一个识别为有效语句。了解为什么双方括号会产生相同的结果会很有帮助。
更新:
看到comments/answer后,我尝试确认双方括号内的表达式是否被视为数组,确实如此。
> const foo = 'foo'
undefined
> const boo = 'boo'
undefined
> const combo = { [foo,boo]: 'foo boo' }
const combo = { [foo,boo]: 'foo boo' } // This doesn't work foo,boo is not a valid expression
^
Uncaught SyntaxError: Unexpected token ','
> const combo = { [[foo,boo]]: 'foo boo' }
undefined
> combo
{ 'foo,boo': 'foo boo' } // Treats expression itself as array and `toString()` gets called on the array producing 'foo,boo' string
在ES6中,[expression]: value
解释如下:
- 评价
expression
- 将结果转换为字符串
- 使用这个字符串作为键
分别是
given [ [a] ]: 'boo'
evaluate [a] => ['foo']
String ['foo'] => 'foo'
result => {'foo': 'boo'}
换句话说,多余的括号将被忽略。