æ¹æ³çå®ä¹
åºçº¿
广æ³å¯ç¨
èª 2015å¹´9æ èµ·ï¼æ¤ç¹æ§å·²å¨ä¸»æµæµè§å¨ä¸å¾å°æ¯æï¼å¯å¨å¤§å¤æ°è®¾å¤åæµè§å¨çæ¬ä¸æ£å¸¸ä½¿ç¨ã
ä» ECMAScript 2015 å¼å§ï¼å¨å¯¹è±¡åå§å¨ä¸å¼å ¥äºä¸ç§æ´ç®çå®ä¹æ¹æ³çè¯æ³ï¼è¿æ¯ä¸ç§ææ¹æ³åç´æ¥èµç»å½æ°çç®åæ¹å¼ã
å°è¯ä¸ä¸
const obj = {
foo() {
return "bar";
},
};
console.log(obj.foo());
// Expected output: "bar"
è¯æ³
var obj = {
property( parameters⦠) {},
*generator( parameters⦠) {},
async property( parameters⦠) {},
async* generator( parameters⦠) {},
// with computed keys:
[property]( parameters⦠) {},
*[generator]( parameters⦠) {},
async [property]( parameters⦠) {},
// compare getter/setter syntax:
get property() {},
set property(value) {}
};
æè¿°
该ç®åè¯æ³ä¸ ECMAScript 2015 çgetteråsetterè¯æ³ç±»ä¼¼ã
å¦ä¸ä»£ç ï¼
var obj = {
foo: function () {
/* code */
},
bar: function () {
/* code */
},
};
ç°å¯è¢«ç®å为ï¼
var obj = {
foo() {
/* code */
},
bar() {
/* code */
},
};
夿³¨ï¼ç®åè¯æ³ä½¿ç¨å
·å彿°è䏿¯å¿å彿°ï¼å¦â¦foo: function() {}â¦ï¼ãå
·å彿°å¯ä»¥ä»å½æ°ä½è°ç¨ï¼è¿å¯¹å¿å彿°æ¯ä¸å¯è½çï¼å ä¸ºæ²¡ææ è¯ç¬¦å¯ä»¥å¼ç¨ï¼ã详ç»ä¿¡æ¯ï¼è¯·åé
functionã
çæå¨æ¹æ³
çæå¨æ¹æ³ä¹å¯ä»¥ç¨è¿ç§ç®åè¯æ³å®ä¹ã使ç¨å®ä»¬æ¶ï¼
- ç®åè¯æ³ä¸çæå·ï¼*ï¼å¿
é¡»åºç°å¨çæå¨ååï¼ä¹å°±æ¯è¯´
* g(){}å¯ä»¥æ£å¸¸å·¥ä½ï¼èg *(){}ä¸è¡ã - éçæå¨æ¹æ³å®ä¹å¯è½ä¸å
å«
yieldå ³é®åãè¿æå³çéçççæå¨å½æ°ä¹ä¸ä¼å·¥ä½ï¼å¹¶ä¸å°æåºSyntaxErrorãå§ç»ä½¿ç¨yield䏿å·ï¼*ï¼ç»å使ç¨ã
// ç¨æå±æ§åçè¯æ³å®ä¹æ¹æ³ï¼ES6 ä¹åï¼ï¼
var obj2 = {
g: function* () {
var index = 0;
while (true) yield index++;
},
};
// åä¸ä¸ªæ¹æ³ï¼ç®åè¯æ³ï¼
var obj2 = {
*g() {
var index = 0;
while (true) yield index++;
},
};
var it = obj2.g();
console.log(it.next().value); // 0
console.log(it.next().value); // 1
Async æ¹æ³
Async æ¹æ³ä¹å¯ä»¥ä½¿ç¨ç®åè¯æ³æ¥å®ä¹ã
// ç¨æå±æ§åçè¯æ³å®ä¹æ¹æ³ï¼ES6 ä¹åï¼ï¼
var obj3 = {
f: async function () {
await some_promise;
},
};
// åä¸ä¸ªæ¹æ³ï¼ç®åè¯æ³ï¼
var obj3 = {
async f() {
await some_promise;
},
};
Async çæå¨æ¹æ³
çæå¨æ¹æ³ä¹è½æä¸º async.
var obj4 = {
f: async function* () {
yield 1;
yield 2;
yield 3;
},
};
// The same object using shorthand syntax
var obj4 = {
async *f() {
yield 1;
yield 2;
yield 3;
},
};
æ¹æ³å®ä¹ä¸æ¯æé 彿°
æææ¹æ³å®ä¹ä¸æ¯æé 彿°ï¼å¦æä½ å°è¯å®ä¾åå®ä»¬ï¼å°æåºTypeErrorã
var obj = {
method() {},
};
new obj.method(); // TypeError: obj.method is not a constructor
var obj = {
*g() {},
};
new obj.g(); // TypeError: obj.g is not a constructor (changed in ES2016)
示ä¾
>ç®å示ä¾
var obj = {
a: "foo",
b() {
return this.a;
},
};
console.log(obj.b()); // "foo"
计ç®ç屿§å
该ç®åè¯æ³è¿æ¯æè®¡ç®ç屿§åç§°ä½ä¸ºæ¹æ³åã
var bar = {
foo0: function () {
return 0;
},
foo1() {
return 1;
},
["foo" + 2]() {
return 2;
},
};
console.log(bar.foo0()); // 0
console.log(bar.foo1()); // 1
console.log(bar.foo2()); // 2
è§è
| è§è |
|---|
| ECMAScript® 2027 Language Specification> # sec-method-definitions> |