JavaScript对象文字:{a,b,c}到底是什么?
我的问题最好通过此jsfiddle给出,其代码如下:
var a = 1, b = 'x', c = true;var d = {a: a, b: b, c: c}; // <--- object literal
var e = [a, b, c]; // <--- array
var f = {a, b, c}; // <--- what exactly is this??
// these all give the same output:
alert(d.a + ', ' + d.b + ', ' + d.c );
alert(e[0] + ', ' + e[1] + ', ' + e[2]);
alert(f.a + ', ' + f.b + ', ' + f.c );
什么样的数据结构是f
?这只是简写d
吗?
回答:
它是ES6中的Object Initializer 属性简写。
var f = {a, b, c, d:1}; // Will be equal to {a:a, b:b, c:c, d:1}
这是可行的,因为属性值与属性标识符具有相同的名称。这是最新ECMAScript6草案Rev13中对象初始化程序第11.1.5节]的语法的新补充。当然,就像ECMAScript3中设置的限制一样,您不能使用保留字作为属性名称。
这样的简写不会显着改变您的代码,只会使所有内容变得更甜蜜!
function createCar(name, brand, speed) { return { type: 'Car', name: name, brand: brand, speed: speed };
}
// With the new shorthand form
function createSweetCar(name, brand, speed) {
return { type: 'Car', name, brand, speed }; // Yes it looks sweet.
}
请参阅兼容性表以获取对这些符号的支持。在不支持的环境中,这些符号将导致语法错误。
在 ,我们曾经做过的事情:
var tmp = getData();var op = tmp.op;
var lhs = tmp.lhs;
var rhs = tmp.rhs;
只需一行代码即可在 中完成:
var { op, lhs, rhs } = getData();
以上是 JavaScript对象文字:{a,b,c}到底是什么? 的全部内容, 来源链接: utcz.com/qa/429023.html