BabelJS-ES7 기능을 ES5로 트랜스 파일

이 장에서는 ES7 기능을 ES5로 변환하는 방법을 배웁니다.

ECMA Script 7에는 다음과 같은 새로운 기능이 추가되었습니다.

  • Async-Await
  • 지수 연산자
  • Array.prototype.includes()

babeljs를 사용하여 ES5로 컴파일합니다. 프로젝트 요구 사항에 따라 모든 ecma 버전, 즉 ES7에서 ES6 또는 ES7에서 ES5로 코드를 컴파일 할 수도 있습니다. ES5 버전이 가장 안정적이며 모든 최신 및 이전 브라우저에서 잘 작동하므로 코드를 ES5로 컴파일합니다.

비동기 대기

Async는 암시 적 약속을 반환하는 비동기 함수입니다. 약속이 해결되거나 거부됩니다. 비동기 기능은 일반 표준 기능과 동일합니다. 이 함수는 promise를 반환 할 때까지 실행을 일시 중지하는 await 표현식을 가질 수 있으며 일단 약속을 받으면 실행이 계속됩니다. Await는 함수가 비동기 인 경우에만 작동합니다.

다음은 async 및 await에 대한 작업 예제입니다.

let timer = () => {
   return new Promise(resolve => {
      setTimeout(() => {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
let out = async () => {
   let msg = await timer();
   console.log(msg);
   console.log("hello after await");
};
out();

산출

Promise resolved after 5 seconds
hello after await

타이머 함수가 호출되기 전에 await 표현식이 추가됩니다. 타이머 기능은 5 초 후에 promise를 반환합니다. 따라서 await는 promise on timer 함수가 해결되거나 거부 될 때까지 실행을 중지하고 나중에 계속합니다.

이제 babel을 사용하여 위의 코드를 ES5로 트랜스 파일하겠습니다.

ES7-비동기 대기

let timer = () => {
   return new Promise(resolve => {
      setTimeout(() => {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
let out = async () => {
   let msg = await timer();
   console.log(msg);
   console.log("hello after await");
};
out();

명령

npx babel asyncawait.js --out-file asyncawait_es5.js

BabelJS-ES5

"use strict";

var timer = function timer() {
   return new Promise(function (resolve) {
      setTimeout(function () {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
var out = async function out() {
   var msg = await timer();
   console.log(msg);
   console.log("hello after await");
};

out();

Babeljs는 객체 나 메소드를 컴파일하지 않습니다. 따라서 여기에서 사용 된 약속은 변환되지 않고있는 그대로 표시됩니다. 오래된 브라우저에서 promise를 지원하려면 promise를 지원하는 코드를 추가해야합니다. 지금은 다음과 같이 babel-polyfill을 설치하겠습니다.

npm install --save babel-polyfill

개발 의존성이 아닌 의존성으로 저장되어야합니다.

브라우저에서 코드를 실행하기 위해 node_modules \ babel-polyfill \ dist \ polyfill.min.js의 polyfill 파일을 사용하고 아래와 같이 스크립트 태그를 사용하여 호출합니다.

<!DOCTYPE html>
<html>
   <head>
      <title>BabelJs Testing</title>
   </head>
   <body>
      <script src="node_modules\babel-polyfill\dist\polyfill.min.js" type="text/javascript"></script>
      <script type="text/javascript" src="aynscawait_es5.js"></script>
   </body>
</html>

위의 테스트 페이지를 실행하면 아래와 같이 콘솔에 출력이 표시됩니다.

지수 연산자

**는 ES7에서 지수화에 사용되는 연산자입니다. 다음 예제는 ES7에서 동일한 작업을 보여 주며 코드는 babeljs를 사용하여 트랜스 파일됩니다.

let sqr = 9 ** 2;
console.log(sqr);

산출

81

ES6-지수

let sqr = 9 ** 2;
console.log(sqr);

지수 연산자를 변환하려면 다음과 같이 설치할 플러그인을 설치해야합니다.

명령

npm install --save-dev babel-plugin-transform-exponentiation-operator

플러그인 세부 정보 추가 .babelrc 다음과 같이 파일-

{
   "presets":[
      "es2015"
   ],
   "plugins": ["transform-exponentiation-operator"]
}

명령

npx babel exponeniation.js --out-file exponeniation_es5.js

BabelJS-ES5

"use strict";

var sqr = Math.pow(9, 2);
console.log(sqr);

Array.prototype.includes ()

이 기능은 전달 된 요소가 배열에 있으면 true를 제공하고 그렇지 않으면 false를 제공합니다.

let arr1 = [10, 6, 3, 9, 17];
console.log(arr1.includes(9));
let names = ['Siya', 'Tom', 'Jerry', 'Bean', 'Ben'];
console.log(names.includes('Tom'));
console.log(names.includes('Be'));

산출

true
true
false

여기서 다시 babel-polyfill을 사용해야합니다. includes배열의 메서드이며 트랜스 파일되지 않습니다. 이전 브라우저에서 작동하도록 polyfill을 포함하려면 추가 단계가 필요합니다.

ES6-array.includes

let arr1 = [10, 6, 3, 9, 17];
console.log(arr1.includes(9));
let names = ['Siya', 'Tom', 'Jerry', 'Bean', 'Ben'];
console.log(names.includes('Tom'));
console.log(names.includes('Be'));

명령

npx babel array_include.js --out-file array_include_es5.js

Babel-ES5

'use strict';

var arr1 = [10, 6, 3, 9, 17];
console.log(arr1.includes(9));
var names = ['Siya', 'Tom', 'Jerry', 'Bean', 'Ben'];
console.log(names.includes('Tom'));
console.log(names.includes('Be'));

이전 브라우저에서 테스트하려면 아래와 같이 polyfill을 사용해야합니다.

<!DOCTYPE html>
<html>
   <head>
      <title>BabelJs Testing</title>
   </head>
   <body>
      <script src="node_modules\babel-polyfill\dist\polyfill.min.js" type="text/javascript"></script>
      <script type="text/javascript" src="array_include_es5.js"></script>
   </body>
</html>

산출