1. 程式人生 > >webpack4與babel配合使es6程式碼可運行於低版本瀏覽器

webpack4與babel配合使es6程式碼可運行於低版本瀏覽器

使用es6+新語法編寫程式碼,可是不能運行於低版本瀏覽器,需要將語法轉換成es5的。那就藉助babel7轉換,再加上webpack打包,實現程式碼的轉換。

轉換包括兩部分:語法和API

let、const這些是新語法。

new promise()等這些是新API。

簡單程式碼

類庫 utils.js

const name = 'weiqinl'

let year = new Date().getFullYear()

export {  name,  year }

index.js

import _ from 'lodash'

import {  name,  year } from './utils'

Promise.resolve(year).then(value => {

  console.log(`${name} - ${value} - ${_.add(1, 2)}`)

})

babel轉換

安裝babel編譯器和對應的執行時環境

npm install -D @babel/core @babel/preset-env @babel/plugin-transform-runtime @babel/polyfill babel-loader

並新建.babelrc檔案,裡面可以配置很多東西,內容為:

{

  "presets": [

    ["@babel/preset-env", {

      "useBuiltIns": "usage",

      "modules": false

    }]

  ],

  "plugins": [

    [

      "@babel/plugin-transform-runtime", {

        "corejs": false,

        "helpers": false,

        "regenerator": false,

        "useESModules": false

      }

    ]

  ],

  "comments": false

}

webpack構建

webpack4,可以零配置構建專案,那是因為它的很多配置值都默認了。在這裡,我們需要自己配置。
首先安裝webpack

npm i webpack webpack-cli -D

然後建立一個webpack.config.js檔案

const path = require('path');

module.exports = {

  mode: "production",

  entry: ['@babel/polyfill', './src/index.js'],

  output: {

    path: path.resolve(__dirname, 'dist'),

    filename: '[name].bundle.js'

  },

  module: {

    rules: [{

      test: /\.js$/,

      include: [

        path.resolve(__dirname, 'src')

      ],

      exclude: /(node_modules|bower_components)/,

      loader: "babel-loader",

    }]

  }

}

使用

webpack構建打包好的js檔案,我們將其引入到html檔案。

<!DOCTYPE html>

<html lang="en">

<head>

  <meta charset="UTF-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0">

  <meta http-equiv="X-UA-Compatible" content="ie=edge">

  <title>webpack-babel-es6</title>

</head>

<body>

  webpack構建由babel轉碼的es6語法,支援es6語法和API<br />

  請檢視瀏覽器控制檯

  <script src="./dist/main.bundle.js"></script>

</body>

</html>

執行該html,可以看到控制檯有內容輸出weiqinl - 2018 - 3

最後的目錄結構:

目錄結構

[完]