webpack4 系列教程(二): 編譯 ES6


今天介紹webpack怎么編譯ES6的各種函數和語法。敲黑板:這是webpack4版本哦, 有一些不同於webpack3的地方。

>>> 本節課源碼

>>> 所有課程源碼

1. 了解babel

說起編譯es6,就必須提一下babel和相關的技術生態:

  1. babel-loader: 負責 es6 語法轉化
  2. babel-preset-env: 包含 es6、7 等版本的語法轉化規則
  3. babel-polyfill: es6 內置方法和函數轉化墊片
  4. babel-plugin-transform-runtime: 避免 polyfill 污染全局變量

需要注意的是, babel-loaderbabel-polyfill。前者負責語法轉化,比如:箭頭函數;后者負責內置方法和函數,比如:new Set()

2. 安裝相關庫

這次,我們的package.json文件配置如下:

{
  "devDependencies": {
    "babel-core": "^6.26.3",
    "babel-loader": "^7.1.5",
    "babel-plugin-transform-runtime": "^6.23.0",
    "babel-preset-env": "^1.7.0",
    "webpack": "^4.15.1"
  },
  "dependencies": {
    "babel-polyfill": "^6.26.0",
    "babel-runtime": "^6.26.0"
  }
}

>>> package.json 配置地址

3. webpack中使用babel

babel的相關配置,推薦單獨寫在.babelrc文件中。下面,我給出這次的相關配置:

{
  "presets": [
    [
      "env",
      {
        "targets": {
          "browsers": ["last 2 versions"]
        }
      }
    ]
  ],
  "plugins": ["transform-runtime"]
}

webpack配置文件中,關於babel的調用需要寫在module模塊中。對於相關的匹配規則,除了匹配js結尾的文件,還應該去除node_module/文件夾下的第三庫的文件(發布前已經被處理好了)。

module.exports = {
  entry: {
    app: "./app.js"
  },
  output: {
    filename: "bundle.js"
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /(node_modules)/,
        use: {
          loader: "babel-loader"
        }
      }
    ]
  }
};

>>> .babelrc 地址

>>> 配置文件地址

4. 最后:babel-polyfill

我們發現整個過程中並沒有使用babel-polyfill它需要在我們項目的入口文件中被引入,或者在webpack.config.js中配置。這里我們采用第一種方法編寫app.js:

import "babel-polyfill";
let func = () => {};
const NUM = 45;
let arr = [1, 2, 4];
let arrB = arr.map(item => item * 2);

console.log(arrB.includes(8));
console.log("new Set(arrB) is ", new Set(arrB));

命令行中進行打包,然后編寫html文件引用打包后的文件即可在不支持es6規范的老瀏覽器中看到效果了。

5. 相關資料


歡迎技術交流,引用請注明出處。
個人網站:Yuan Xin
原文鏈接:webpack4 系列教程(二): 編譯 ES6


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM