Front-End/Javascript
ECMAScript 2020
태나미
2021. 4. 8. 11:30
ECMAScript 6부터 일 년 단위 릴리스(yearly release)로 변경된 이후로, 해마다 연도별 명세가 완성되고 공개되고 있다.
2020 6월18일 ECMAScript 2020(ECMA-262 11번째 에디션)이 공식적으로 릴리스 되었다.
ECMAScript 2020
릴리스된 내용들을 살펴보겠다.
Optional Chaining (?.)
연산자인 ?.는 연결된 체인의 속성 값이 nullish(null 또는 undefined)인 경우, undefined를 반환한다.
const title = data && data.article && data.article.title
// 위의 표현식은 다음의 optional chaining 연산자를 통해 동일하게 표현될 수 있다.
const title = data?.article?.title
// data.article.title 값이 존재하는 경우, title 값을 반환
// 그렇지 않은 경우에는 undefined를 반환
const friends = {
jihun: {
age: 28,
getAge() {
return this.age;
}
},
changhan: {
age: 28,
getAge() {
return this.age;
}
}
}
const jihun = friends?.jihun
// 위와 동일한 동작을 함
const jihun2 = friends !== undefined && friends !== null ? friends.jihun : undefined
const changhanGetAge = friends?.changhan.getAge?.() // foo
const changhanGetHeight = friends?.changhan.height // undefined
Nullish coalescing Operator (??)
연산자인 ??는 좌측 값이 null 또는 undefined 한 값인 경우에만 평가한다.
"" || "default value"
// default value
null ?? "default value"
// default value
"" ?? "default value"
// ""
false ?? "default value"
// false
export * as ns from "mod";
모듈을 모두 import한 후, 새로운 이름(namespace)로 export할 수 있게 하는 문법
export * as ns from "mod";
globalThis
globalThis는 환경에 따라 다른 최상위 객체(브라우저의 경우 window, Node.js의 경우 global 등) 접근 방법의 상이함으로 인한 불편을 해소, 모든 환경에서 동일 객체를 사용해 접근할 수 있게 한다. 모든 주요 브라우저에서 지원된다.
globalThis.setTimeout; // window.setTimeout
Promise.allSettled
나열된 여러 개의 Promise 모음이 모두 처리(settled)(이행(fulfilled) 또는 거부(rejected))된 후, 각 Promise의 결과 값의 컬렉션을 반환한다.
const promise1 = Promise.resolve(5);
const promise2 = new Promise((resolve, reject) => {
setTimeout(resolve, 500, 222);
});
const promise3 = new Promise((resolve, reject) => {
setTimeout(reject, 100, 3333);
});
Promise.all([promise1, promise2, promise3]).then((values) => {
console.log(values);
});
// -----------------------------------------------------------
const promise4 = Promise.resolve(4);
const promise5 = new Promise((resolve, reject) => setTimeout(reject, 700, 'foo'));
Promise.allSettled([promise4, promise5]).
then((results) => console.log(results));
// Promise.allSetteld의 결과값
// [
// {
// "status": "fulfilled",
// "value": 4
// },
// {
// "status": "rejected",
// "reason": "foo"
// }
// ]
// Promise.all의 결과값
// Uncaught (in promise) 3333
for-in mechanics
명확하지 않았던 for-in 열거 순서에 대한 방식을 정의한다.
var o = {
p1: 'p1',
p2: 'p2',
p3: 'p3',
};
var keys = [];
for (var key in o) {
if (key === 'p1') {
o.p4 = 'p4';
}
keys.push(key);
}
console.log(keys);
// ['p1', 'p2', 'p3']
// IE8의 경우: ['p1', 'p2', 'p3', 'p4']
출처 :
d2.naver.com/helloworld/4268738