Javascript/[기초] Javascript
ES7, ES8 기능 정리(ECMAScript 7, ECMAScript 8)
마샤와 곰
2021. 2. 4. 13:30
* ES7 기능
1. 거듭 제곱을 쉽게 할 수 있습니다.
var i = 2
i **= 3 // 8이 출력됩니다.
2. 포함여부를 판별하는 includes 입니다.
//3이 있는지 찾습니다.
[1, 2, 3, 4, 5].includes(3) //true
//1이 첫번째에 있는지 찾습니다.
[1, 2, 3, 4, 5].includes(1, 0) //true
* ES8 기능
1. 문자 앞뒤 간격을 조절할 수 있습니다.
//앞으로 10칸
console.log("hello".padStart(10)) // " hello"
//뒤로 10칸
console.log("hello".padEnd(10)) // "hello "
2. key와 value로 되어있는 객체(json형식)에 대해서 손쉬운 반복문이 가능 합니다.
let datas = {
data1 : "데이터1",
data2 : "데이터2",
data3 : "데이터3",
};
//#1. key와 인덱스를 통한 출력
Object.keys(datas).forEach((key, index) => {
console.log(key, datas[key]);
});
//#2. 데이터만 출력
Object.values(datas).forEach((value) => {
console.log(value);
});
//#3. 객체를 배열로 변환(key가 0번째, 데이터가1번째 순서로)
Object.entries(datas).forEach((value) => {
console.log(value);
});
3. async, await
- 프로미스(Promise)를 사용하는 객체에게 동기화를 통하여 기다리게 할 수 있습니다.
- async는 기다려야하는 함수에게 붙여주며, await는 프로미스(Promise)가 실행되는 구간에 붙여줍니다.
- 이러한 방법은 콜백 지옥, then 지옥에서 벗어나게 해 주지만 async를 통해 기능이 정체되므로 사용시에 성능에 대해 반드시 고려를 해야 합니다.
function endAfter2Seconds() {
return new Promise(resolve => {
setTimeout(() => {
resolve('끝~');
}, 2000);
});
}
async function waitPromiseFunction() {
console.log('시작했습니다.');
var result = await endAfter2Seconds();
console.log('기다려준 상태로 끝났습니다 : ', result);
}
waitPromiseFunction();
ES7, ES8 문법에서의 주의사항으로는,
익.스.플.로.러에서는 동작을 안한다는 점 입니다..ㅠㅠ
그러므로 대부분의 개발자들이 이러한 좋은 기능을 사용하지 못하고 어쩔수 없이 예전방식만 사용하는게 아닌가 싶습니다.
반응형