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

    原文作者:心谭
    原文地址: https://segmentfault.com/a/1190000015837338
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞