BabelJS - Babel Polyfill

Babel Polyfill bổ sung hỗ trợ cho các trình duyệt web đối với các tính năng không có sẵn. Babel biên dịch mã từ phiên bản ecma gần đây sang phiên bản mà chúng tôi muốn. Nó thay đổi cú pháp theo giá trị đặt trước, nhưng không thể làm gì đối với các đối tượng hoặc phương thức được sử dụng. Chúng tôi phải sử dụng polyfill cho các tính năng đó để tương thích ngược.

Các tính năng có thể được làm đầy

Sau đây là danh sách các tính năng cần hỗ trợ polyfill khi được sử dụng trong các trình duyệt cũ hơn -

  • Promises
  • Map
  • Set
  • Symbol
  • Weakmap
  • Weakset
  • Array.from, Array.includes, Array.of, Array # find, Array.buffer, Array # findIndex
  • Object.assign, Object.entries, Object.values

Chúng tôi sẽ tạo thiết lập dự án và cũng xem hoạt động của polyfill babel.

chỉ huy

npm init

Bây giờ chúng ta sẽ cài đặt các gói cần thiết cho babel.

Các gói cho babel 6

npm install babel-cli babel-core babel-preset-es2015 --save-dev

Các gói cho babel 7

npm install @babel/cli @babel/core @babel/preset-env --save-dev

Đây là gói cuối cùng.json -

Chúng tôi cũng sẽ thêm es2015 vào các cài đặt trước, vì chúng tôi muốn biên dịch mã thành es5.

.babelrc for babel 6

.babelrc for babel 7

{
   "presets":["@babel/env"]
}

Chúng tôi sẽ cài đặt một phiên bản nhỏ để chúng tôi có thể kiểm tra mã của mình trong trình duyệt -

npm install --save-dev lite-server

Hãy để chúng tôi thêm lệnh babel để biên dịch mã của chúng tôi trong package.json -

Chúng tôi cũng đã thêm lệnh xây dựng gọi máy chủ lite.

Babel-polyfill được cài đặt cùng với gói babel-core. Babel-polyfill sẽ có sẵn trong các mô-đun nút như hình dưới đây -

Chúng tôi sẽ tiếp tục làm việc với những lời hứa và sử dụng babel-polyfill cùng với nó.

ES6 - Lời hứa

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

timingpromise.then((msg) => {
   console.log("%c"+msg, "font-size:25px;color:red;");
});

chỉ huy

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("%c"+msg, "font-size:25px;color:red;");
});

Việc biên dịch không cần thay đổi bất cứ điều gì. Mã cho lời hứa đã được chuyển đổi như nó vốn có. Nhưng các trình duyệt không hỗ trợ các hứa hẹn sẽ gây ra lỗi mặc dù chúng tôi đã biên dịch mã thành es5.

Để giải quyết vấn đề này, chúng ta cần thêm polyfill cùng với mã đã biên dịch es5 cuối cùng. Để chạy mã trong trình duyệt, chúng tôi sẽ lấy tệp babel-polyfill từ các mô-đun nút và thêm nó vào tệp .html nơi chúng tôi muốn sử dụng các hứa hẹn như được hiển thị bên dưới -

index.html

<html>
   <head>
   </head>
   <body>
      <h1>Babel Polyfill Testing</h1>
      <script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>
      <script type="text/javascript" src="promise_es5.js"></script>
   </body>
</html>

đầu ra

Trong tệp index.html, chúng tôi đã sử dụng tệp polyfill.min.js từ node_modules theo sau bởi promise_es5.js -

<script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>

<script type="text/javascript" src="promise_es5.js"></script>

Note - Tệp polyfill phải được sử dụng ngay từ đầu trước lệnh gọi javascript chính.

Đệm chuỗi

Phần đệm chuỗi thêm một chuỗi khác từ phía bên trái theo độ dài được chỉ định. Cú pháp cho phần đệm chuỗi như được hiển thị bên dưới:

Cú pháp

str.padStart(length, string);
str.padEnd(length, string);

Thí dụ

const str = 'abc';

console.log(str.padStart(8, '_'));
console.log(str.padEnd(8, '_'));

Đầu ra

_____abc
abc_____

Babel - ES5

npx babel strpad.js --out-file strpad_es5.js

chỉ huy

'use strict';

var str = 'abc';

console.log(str.padStart(8, '_'));
console.log(str.padEnd(8, '_'));

Các js phải được sử dụng cùng với babel-polyfill như hình dưới đây -

test.html

<!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="strpad_es5.js"></script>
   </body>
</html>

Bản đồ, Đặt, WeakSet, WeakMap

Trong phần này, chúng ta sẽ tìm hiểu vềMap, Set, WeakSet, WeakMap.

  • Map là một đối tượng có cặp khóa / giá trị.

  • Set cũng là một đối tượng nhưng mang những giá trị riêng biệt.

  • WeakMap and WeakSet iare cũng là các đối tượng có cặp khóa / giá trị.

Map, Set, WeakMap và WeakSet là những tính năng mới được thêm vào ES6. Để chuyển mã nó được sử dụng trong các trình duyệt cũ hơn, chúng ta cần sử dụng polyfill. Chúng tôi sẽ làm việc trên một ví dụ và sử dụng polyfill để biên dịch mã.

Thí dụ

let m = new Map(); //map example
m.set("0","A");
m.set("1","B");
console.log(m);

let set = new Set(); //set example
set.add('A');
set.add('B');
set.add('A');
set.add('B');
console.log(set);

let ws = new WeakSet(); //weakset example
let x = {};
let y = {};
ws.add(x);
console.log(ws.has(x));
console.log(ws.has(y));

let wm = new WeakMap(); //weakmap example
let a = {};
wm.set(a, "hello");
console.log(wm.get(a));

Đầu ra

Map(2) {"0" => "A", "1" => "B"}
Set(2) {"A", "B"}
true
false
hello

chỉ huy

npx babel set.js --out-file set_es5.js

Babel-ES5

"use strict";

var m = new Map(); //map example
m.set("0", "A");
m.set("1", "B");
console.log(m);

var set = new Set(); //set example
set.add('A');
set.add('B');
set.add('A');
set.add('B');
console.log(set);

var ws = new WeakSet(); //weakset example
var x = {};
var y = {};
ws.add(x);
console.log(ws.has(x));
console.log(ws.has(y));

var wm = new WeakMap(); //weakmap example
var a = {};
wm.set(a, "hello");
console.log(wm.get(a));

Các js phải được sử dụng cùng với babel-polyfill như hình dưới đây -

test.html

<!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="set_es5.js"></script>
   </body>
</html>

Đầu ra

Phương thức mảng

Nhiều thuộc tính và phương thức có thể được sử dụng trên mảng; ví dụ: array.from, array.includes, v.v.

Chúng ta hãy xem xét làm việc trên ví dụ sau để hiểu điều này tốt hơn.

Thí dụ

arraymethods.js

var arrNum = [1, 2, 3];

console.log(arrNum.includes(2));
console.log(Array.from([3, 4, 5], x => x + x));

Output

true
[6, 8, 10]

chỉ huy

npx babel arraymethods.js --out-file arraymethods_es5.js

Babel-es5

"use strict";

var arrNum = [1, 2, 3];

console.log(arrNum.includes(2));
console.log(Array.from([3, 4, 5], function (x) {
return x + x;
}));

Các phương thức được sử dụng trên mảng được in như chúng vốn có. Để làm cho chúng hoạt động trên các trình duyệt cũ hơn, chúng tôi cần thêm tệp polyfill vào đầu như hình dưới đây -

index.html

<html>
   <head></head>
   <body>
      <h1>Babel Polyfill Testing</h1>
      <script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>
      <script type="text/javascript" src="arraymethods_es5.js"></script>
   </body>
</html>

Đầu ra