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

이 장에서는 ES6에 추가 된 기능을 살펴 보겠습니다. 또한 BabelJS를 사용하여 기능을 ES5로 컴파일하는 방법을 배웁니다.

다음은이 장에서 논의 할 다양한 ES6 기능입니다.

  • Let + Const
  • 화살표 기능
  • Classes
  • Promises
  • Generators
  • Destructuring
  • Iterators
  • 템플릿 리터럴 스트
  • 향상된 개체
  • 기본, 휴식 및 스프레드 속성

Let + Const

JavaScript에서 블록 범위 지역 변수를 선언합니다. let의 사용을 이해하려면 다음 예제를 고려하십시오.

let a = 1;
if (a == 1) {
   let a = 2;
   console.log(a);
}
console.log(a);

산출

2
1

첫 번째 콘솔이 2를 인쇄하는 이유는 a 다음을 사용하여 다시 선언됩니다. let 에서만 사용할 수 있습니다. if블록. let을 사용하여 선언 된 모든 변수는 선언 된 블록 내에서만 사용할 수 있습니다. let을 사용하여 변수 a를 두 번 선언했지만 a의 값을 덮어 쓰지 않습니다.

이것이 var와 let 키워드의 차이점입니다. var를 사용하여 변수를 선언하면 함수 범위 내에서 변수를 사용할 수 있거나 선언 된 경우 전역 변수처럼 작동합니다.

let으로 변수를 선언하면 블록 범위 내에서 변수를 사용할 수 있습니다. if 문 내에서 선언하면 if 블록 내에서만 사용할 수 있습니다. 스위치, for 루프 등에 동일하게 적용됩니다.

이제 babeljs를 사용하여 ES5에서 코드 변환을 볼 수 있습니다.

다음 명령을 실행하여 코드를 변환 해 보겠습니다.

npx babel let.js --out-file let_es5.js

let 키워드에 대한 es6에서 es5 로의 출력은 다음과 같습니다.

ES6를 사용하자

let a = 1;
if (a == 1) {
   let a = 2;
   console.log(a);
}
console.log(a);

바벨을 사용하여 ES5로 트랜스 파일

"use strict";

var a = 1;
if (a == 1) {
   var _a = 2;
   console.log(_a);
}
console.log(a);

ES5 코드가 보이면 let 키워드가 var예어. 또한 if 블록 내부의 변수 이름이_a 다음과 같이 선언했을 때와 동일한 효과를 갖도록 let 예어.

Const

이 섹션에서는 ES6 및 ES5에서 const 키워드의 작동에 대해 배웁니다. Const 키워드도 범위 내에서 사용할 수 있습니다. 외부에 있으면 오류가 발생합니다. const 선언 된 변수의 값은 할당 된 후에는 변경할 수 없습니다. const 키워드가 어떻게 사용되는지 이해하기 위해 다음 예제를 고려해 보겠습니다.

let a =1;
if (a == 1) {
   const age = 10;
}
console.log(age);

산출

Uncaught ReferenceError: age is not defined at 
      
       :5:13 
      

위의 출력은 const age가 if 블록 내에 정의되고 if 블록 내에서 사용할 수 있으므로 오류가 발생합니다.

우리는 BabelJS를 사용하여 ES5 로의 변환을 이해할 것입니다.

ES6

let a =1;
if (a == 1) {
   const age = 10;
}
console.log(age);

명령

npx babel const.js --out-file const_es5.js

BabelJS를 사용하여 ES6로 트랜스 파일

"use strict";

var a = 1;
if (a == 1) {
   var _age = 10;
}
console.log(age);

ES5의 경우 const 키워드는 위와 같이 var 키워드로 대체됩니다.

화살표 기능

Arrow 함수는 변수 표현식에 비해 구문이 더 짧습니다. 지방 화살표 함수 또는 람다 함수라고도합니다. 함수에는 고유 한이 속성이 없습니다. 이 함수에서는 키워드 함수가 생략됩니다.

var add = (x,y) => {
   return x+y;
}

var k = add(3,6);
console.log(k);

산출

9

BabelJS를 사용하여 위 코드를 ES5로 트랜스 파일합니다.

ES6-화살표 기능

var add = (x,y) => {
   return x+y;
}

var k = add(3,6);
console.log(k);

명령

npx babel arrowfunction.js --out-file arrowfunction_es5.js

BabelJS-ES5

Babel을 사용하여 화살표 함수는 아래와 같이 변수 표현 함수로 변환됩니다.

"use strict";

var add = function add(x, y) {
   return x + y;
};

var k = add(3, 6);
console.log(k);

클래스

ES6에는 새로운 클래스 기능이 있습니다. 클래스는 ES5에서 사용할 수있는 프로토 타입 기반 상속과 유사하며 class 키워드는 클래스를 정의하는 데 사용됩니다. 클래스는 특수 함수와 같으며 함수 표현과 유사합니다. 클래스 내부에서 호출되는 생성자가 있습니다.

class Person {
   constructor(fname, lname, age, address) {
      this.fname = fname;
      this.lname = lname;
      this.age = age;
      this.address = address;
   }

   get fullname() {
      return this.fname +"-"+this.lname;
   }
}
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

산출

Siya-Kapoor

ES6-수업

class Person {
   constructor(fname, lname, age, address) {
      this.fname = fname;
      this.lname = lname;
      this.age = age;
      this.address = address;
   }

   get fullname() {
      return this.fname +"-"+this.lname;
   }
}
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

명령

npx babel class.js --out-file class_es5.js

BabelJS-ES5

babeljs를 사용하여 ES5에서와 동일한 클래스에서 작동하는 기능을 얻기 위해 추가 코드가 추가되었습니다. BabelJs는 기능이 ES6에서와 동일하게 작동하는지 확인합니다.

"use strict";

var _createClass = function () {
   function defineProperties(target, props) {
      for (var i = 0; i < props.length; i++) {
         var descriptor = props[i];
         descriptor.enumerable = descriptor.enumerable || false;
         descriptor.configurable = true;
         if ("value" in descriptor) descriptor.writable = true;
         Object.defineProperty(target, descriptor.key, descriptor);
      }
   }
   return function (Constructor, protoProps, staticProps) {
      if (protoProps) defineProperties(Constructor.prototype, protoProps);
      if (staticProps) defineProperties(Constructor, staticProps);
      return Constructor;
   };
}();

function _classCallCheck(instance, Constructor) {
   if (!(instance instanceof Constructor)) {
      throw new TypeError("Cannot call a class as a function");
   }
}

var Person = function () {
   function Person(fname, lname, age, address) {
      _classCallCheck(this, Person);

      this.fname = fname;
      this.lname = lname;
      this.age = age;
      this.address = address;
   }

   _createClass(Person, [{
      key: "fullname",
      get: function get() {
         return this.fname + "-" + this.lname;
      }
   }]);

   return Person;
}();

var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

약속

JavaScript promise는 코드에서 비동기 요청을 관리하는 데 사용됩니다.

종속성이있는 비동기 요청에서 여러 콜백을 관리하므로 삶이 더 쉬워지고 코드가 깔끔하게 유지됩니다. Promise는 콜백 함수로 작업하는 더 나은 방법을 제공합니다. 약속은 ES6의 일부입니다. 기본적으로 약속을 만들 때 약속의 상태는 보류 중입니다.

약속은 세 가지 상태로 나뉩니다.

  • 보류 중 (초기 상태)
  • 해결됨 (성공적으로 완료 됨)
  • rejected(failed)

new Promise()약속을 구성하는 데 사용됩니다. Promise 생성자에는 콜백 함수 인 하나의 인수가 있습니다. 콜백 함수에는 해결과 거부의 두 가지 인수가 있습니다.

둘 다 내부 기능입니다. 작성한 비동기 코드, 즉 Ajax 호출, 이미지 로딩, 타이밍 함수는 콜백 함수에 들어갑니다.

콜백 함수에서 수행 된 작업이 성공하면 resolve 함수가 호출됩니다. 그렇지 않으면 오류 세부 정보와 함께 거부 함수가 호출됩니다.

다음 코드 줄은 약속 구조 호출을 보여줍니다-

var _promise = new Promise (function(resolve, reject) {
   var success = true;
   if (success) {
      resolve("success");
   } else {
      reject("failure");
   }
});
_promise.then(function(value) {
   //once function resolve gets called it comes over here with the value passed in resolve
   console.log(value); //success
}).catch(function(value) {
   //once function reject gets called it comes over here with the value passed in reject
   console.log(value); // failure.
});

ES6 약속 예

let timingpromise = new Promise((resolve, reject) => {
   setTimeout(function() {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then((msg) => {
   console.log(msg);
});

산출

Promise is resolved!

ES6-약속

let timingpromise = new Promise((resolve, reject) => {
   setTimeout(function() {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then((msg) => {
   console.log(msg);
});

명령

npx babel promise.js --out-file promise_es5.js

BabelJS-ES5

"use strict";

var timingpromise = new Promise(function (resolve, reject) {
   setTimeout(function () {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then(function (msg) {
   console.log(msg);
});

Promise의 경우 코드는 트랜스 파일 될 때 변경되지 않습니다. 이전 브라우저에서 작동하려면 babel-polyfill을 사용해야합니다. babel-polyfill에 대한 자세한 내용은 babel-poyfill 장에서 설명합니다.

발전기

생성기 기능은 정상과 같습니다. function. 이 함수에는 함수 내에서 사용할 함수 및 yield 키워드에 대한 *가있는 특수 구문 함수 *가 있습니다. 이는 필요할 때 기능을 일시 중지하거나 시작하기위한 것입니다. 실행이 시작되면 그 사이에 정상 기능을 중지 할 수 없습니다. 전체 함수를 실행하거나 return 문을 만나면 중지됩니다. 생성기는 여기서 다르게 수행하므로 yield 키워드로 함수를 중지하고 필요할 때마다 생성기를 다시 호출하여 시작할 수 있습니다.

function* generatorfunction(a) {
   yield a;
   yield a +1 ;
}

let g = generatorfunction(8);
console.log(g.next());
console.log(g.next());

산출

{value: 8, done: false}
{value: 9, done: false}

ES6-발전기

function* generatorfunction(a) {
   yield a;
   yield a +1 ;
}

let g = generatorfunction(8);
console.log(g.next());
console.log(g.next());

명령

npx babel generator.js --out-file generator_es5.js

BabelJS-ES5

"use strict";

var _marked = /*#__PURE__*/regeneratorRuntime.mark(generatorfunction);

function generatorfunction(a) {
   return regeneratorRuntime.wrap(function generatorfunction$(_context) {
      while (1) {
         switch (_context.prev = _context.next) {
            case 0:
               _context.next = 2;
               return a;

            case 2:
               _context.next = 4;
               return a + 1;
               
            case 4:
            case "end":
               return _context.stop();
         }
      }
   }, _marked, this);
}

var g = generatorfunction(8);
console.log(g.next());
console.log(g.next());

반복자

JavaScript의 Iterator는 값이있는 JavaScript 객체를 반환합니다. 객체에는 true / false 값이있는 done이라는 플래그도 있습니다. 반복자의 끝이 아니면 false를 제공합니다. 예제를 고려하고 배열에서 반복자의 작동을 살펴 보겠습니다.

let numbers = [4, 7, 3, 10];
let a = numbers[Symbol.iterator]();
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());

위의 예에서 우리는 숫자 배열을 사용하고 배열에서 함수를 호출했습니다. Symbol.iterator 색인으로.

배열에서 next ()를 사용하여 얻은 출력은 다음과 같습니다.

{value: 4, done: false}
{value: 7, done: false}
{value: 3, done: false}
{value: 10, done: false}
{value: undefined, done: true}

출력은 값이있는 객체를 제공하고 속성으로 수행됩니다. 마다next()메소드 호출은 배열에서 다음 값을 제공하며 false로 수행됩니다. done의 값은 배열의 요소가 완료된 경우에만 참이됩니다. 배열을 반복하는 데 이것을 사용할 수 있습니다. 다음과 같은 더 많은 옵션을 사용할 수 있습니다.for-of 다음과 같이 사용되는 루프-

let numbers = [4, 7, 3, 10];
for (let n of numbers) {
   console.log(n);
}

산출

4
7
3
10

for-of loop키를 사용하면 위와 같이 배열 값에 대한 세부 정보를 제공합니다. 두 조합을 모두 확인하고 babeljs가 어떻게 es5로 변환하는지 살펴 보겠습니다.

let numbers = [4, 7, 3, 10];
let a = numbers[Symbol.iterator]();
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());

let _array = [4, 7, 3, 10];
for (let n of _array) {
   console.log(n);
}

명령

npx babel iterator.js --out-file iterator_es5.js

산출

"use strict";

var numbers = [4, 7, 3, 10];
var a = numbers[Symbol.iterator]();
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());

var _array = [4, 7, 3, 10];
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;

try {
   for (var _iterator = _array[Symbol.iterator](),
      _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done);
      _iteratorNormalCompletion = true) {
      var n = _step.value;

      console.log(n);
   }
} catch (err) {
   _didIteratorError = true;
   _iteratorError = err;
} finally {
   try {
      if (!_iteratorNormalCompletion && _iterator.return) {
         _iterator.return();
      }
   } finally {
      if (_didIteratorError) {
         throw _iteratorError;
      }
   }
}

추가 된 변경 사항이 있습니다 for-ofes5의 루프. 그러나 iterator.next는 그대로 남아 있습니다. 우리는 사용해야합니다babel-polyfill이전 브라우저에서 작동하도록합니다. Babel-polyfill은 babel과 함께 설치되며 아래와 같이 node_modules에서 사용할 수 있습니다.

<html>
   <head>
      <script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>
      <script type="text/javascript" src="iterator_es5.js"></script>
   </head>
   <body>
      <h1>Iterators</h1>
   </body>
</html>

산출

구조화

Destructuring 속성은 배열, 객체에서 값을 압축 해제하는 JavaScript 표현식처럼 작동합니다.

다음 예제는 구문 분해 작업을 설명합니다.

let x, y, rem;
[x, y] = [10, 20];

console.log(x);
console.log(y);
[x, y, ...rem] = [10, 20, 30, 40, 50];
console.log(rem);

let z = 0;
({ x, y } = (z) ? { x: 10, y: 20 } : { x: 1, y: 2 });
console.log(x);
console.log(y);

산출

10
20
[30, 40, 50]
1
2

위의 코드 줄은 배열의 오른쪽에서 왼쪽의 변수로 값이 할당되는 방식을 보여줍니다. 변수...rem 배열에서 나머지 값을 모두 가져옵니다.

또한 아래와 같이 조건 연산자를 사용하여 왼쪽에있는 객체의 값을 할당 할 수 있습니다.

({ x, y } = (z) ? { x: 10, y: 20 } : { x: 1, y: 2 });
console.log(x); // 1
console.log(y); // 2

babeljs를 사용하여 동일한 것을 ES5로 변환 해 보겠습니다.

명령

npx babel destructm.js --out-file destruct_es5.js

destruct_es5.js

"use strict";

var x = void 0,
   y = void 0,
   rem = void 0;
x = 10;
y = 20;

console.log(x);
console.log(y);
x = 10;
y = 20;
rem = [30, 40, 50];

console.log(rem);

var z = 0;

var _ref = z ? { x: 10, y: 20 } : { x: 1, y: 2 };

x = _ref.x;
y = _ref.y;

console.log(x);
console.log(y);

템플릿 리터럴

템플릿 리터럴은 그 안에 표현식을 허용하는 문자열 리터럴입니다. 작은 따옴표 나 큰 따옴표 대신 backtick (``)를 사용합니다. 문자열 내부에서 표현식을 말하면 문자열 내부에서 변수를 사용하고 함수를 호출 할 수 있음을 의미합니다.

let a = 5;
let b = 10;
console.log(`Using Template literal : Value is ${a + b}.`);
console.log("Using normal way : Value is " + (a + b));

산출

Using Template literal : Value is 15.
Using normal way : Value is 15

ES6-템플릿 리터럴

let a = 5;
let b = 10;
console.log(`Using Template literal : Value is ${a + b}.`);
console.log("Using normal way : Value is " + (a + b));

명령

npx babel templateliteral.js --out-file templateliteral_es5.js

BabelJS-ES5

"use strict";

var a = 5;
var b = 10;
console.log("Using Template literal : Value is " + (a + b) + ".");

console.log("Using normal way : Value is " + (a + b));

향상된 개체 리터럴

es6에서 객체 리터럴에 추가 된 새로운 기능은 매우 훌륭하고 유용합니다. ES5와 ES6에서 객체 리터럴의 몇 가지 예를 살펴 보겠습니다.

ES5
var red = 1, green = 2, blue = 3;
var rgbes5 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes5); // {red: 1, green: 2, blue: 3}

ES6
let rgbes6 = {
   red,
   green,
   blue
};
console.log(rgbes6); // {red: 1, green: 2, blue: 3}

위의 코드가 보이면 ES5와 ES6의 객체가 다릅니다. ES6에서는 변수 이름이 키와 같으면 키 값을 지정할 필요가 없습니다.

babel을 사용하여 ES5에 대한 컴파일을 살펴 보겠습니다.

ES6- 향상된 개체 리터럴

const red = 1, green = 2, blue = 3;
let rgbes5 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes5);

let rgbes6 = {
   red,
   green,
   blue
};
console.log(rgbes6);

let brand = "carbrand";
const cars = {
   [brand]: "BMW"
}
console.log(cars.carbrand);  //"BMW"

명령

npx babel enhancedobjliteral.js --out-file enhancedobjliteral_es5.js

BabelJS-ES5

"use strict";

function _defineProperty(obj, key, value) {
   if (key in obj) {
      Object.defineProperty(obj, key, {
         value: value, enumerable: true, configurable: true, writable: true
      });
   } else { obj[key] = value; } return obj;
}

var red = 1,
   green = 2,
   blue = 3;
var rgbes5 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes5);

var rgbes6 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes6);

var brand = "carbrand";
var cars = _defineProperty({}, brand, "BMW");

console.log(cars.carbrand); //"BMW"

기본, 휴식 및 스프레드 속성

이 섹션에서는 기본, 나머지 및 스프레드 속성에 대해 설명합니다.

기본

ES6에서는 다음과 같이 함수 매개 변수에 기본 매개 변수를 사용할 수 있습니다.

let add = (a, b = 3) => {
   return a + b;
}

console.log(add(10, 20));  // 30
console.log(add(10));      // 13

바벨을 사용하여 위의 코드를 ES5로 트랜스 파일 해 보겠습니다.

명령

npx babel default.js --out-file default_es5.js

BabelJS-ES5

"use strict";

var add = function add(a) {
   var b = arguments.length > 1 >> arguments[1] !== undefined ? arguments[1] : 3;
   return a + b;
};

console.log(add(10, 20));
console.log(add(10));

쉬다

Rest 매개 변수는 아래 예제와 같이 세 개의 점 (...)으로 시작합니다.

let add = (...args) => {
   let sum = 0;
   args.forEach(function (n) {
      sum += n;
   });
   return sum;
};

console.log(add(1, 2));    // 3
console.log(add(1, 2, 5, 6, 6, 7));   //27

위의 함수에서 n 개의 매개 변수를 add 함수에 전달합니다. ES5에있는 경우 이러한 모든 매개 변수를 추가하려면 인수의 세부 정보를 얻기 위해 arguments 객체에 의존해야합니다. ES6를 사용하면rest it 위에 표시된 것처럼 세 개의 점으로 인수를 정의하는 데 도움이되며이를 반복하여 숫자의 합계를 얻을 수 있습니다.

Note − 세 개의 점, 즉 휴식을 사용할 때 추가 인수를 사용할 수 없습니다.

let add = (...args, value) => {    //syntax error
   let sum = 0;
   args.forEach(function (n) {
      sum += n;
   });
   return sum;
};

위의 코드는 구문 오류를 제공합니다.

es5에 대한 컴파일은 다음과 같습니다.

명령

npx babel rest.js --out-file rest_es5.js

바벨 -ES5

"use strict";

var add = function add() {
   for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
      args[_key] = arguments[_key];
   }

   var sum = 0;
   args.forEach(function (n) {
      sum += n;
   });
   return sum;
};

console.log(add(1, 2));
console.log(add(1, 2, 5, 6, 6, 7));

확산

Spread 속성에는 휴식과 같은 세 개의 점이 있습니다. 다음은 spread 속성을 사용하는 방법을 보여주는 작업 예제입니다.

let add = (a, b, c) => {
   return a + b + c;
}
let arr = [11, 23, 3];
console.log(add(...arr));   //37

이제 위의 코드가 babel을 사용하여 어떻게 트랜스 파일되는지 보겠습니다.

명령

npx babel spread.js --out-file spread_es5.js

Babel-ES5

"use strict";

var add = function add(a, b, c) {
   return a + b + c;
};
var arr = [11, 23, 3];
console.log(add.apply(undefined, arr));

프록시

프록시는 속성 조회, 할당, 열거, 함수, 호출 등과 같은 작업에 대한 사용자 지정 동작을 정의 할 수있는 개체입니다.

통사론

var a = new Proxy(target, handler);

대상핸들러는 개체입니다.

  • target 은 개체이거나 다른 프록시 요소 일 수 있습니다.

  • 핸들러 는 호출 될 때 동작을 제공하는 함수로서의 속성을 가진 객체입니다.

예를 들어 이러한 기능을 이해해 보겠습니다.

let handler = {
   get: function (target, name) {
      return name in target ? target[name] : "invalid key";
   }
};

let o = {
   name: 'Siya Kapoor',
   addr: 'Mumbai'
}

let a = new Proxy(o, handler);
console.log(a.name);
console.log(a.addr);
console.log(a.age);

위의 예제에서 대상과 핸들러를 정의하고 프록시와 함께 사용했습니다. 프록시는 키-값이있는 객체를 반환합니다.

산출

Siya Kapoor
Mumbai
invalid key

이제 바벨을 사용하여 위 코드를 ES5로 트랜스 파일하는 방법을 살펴 보겠습니다.

명령

npx babel proxy.js --out-file proxy_es5.js

Babel-ES5

'use strict';

var handler = {
   get: function get(target, name) {
      return name in target ? target[name] : "invalid key";
   }
};

var o = {
   name: 'Siya Kapoor',
   addr: 'Mumbai'
};

var a = new Proxy(o, handler);
console.log(a.name);
console.log(a.addr);
console.log(a.age);