Hot module updates and uses Babel to handle ES6 syntax

1. The hot module is updated

  • Why update with hot modules? For example, if I make a CSS style change and want to render the style without refreshing the HTML of the current page, I need to use the hot module update.

In the webpack.config.js file, configure devServer and plugins

Module. exports = {devServer:{open:true, // webpack = require('webpack') // webpack = require('webpack') // webpack = require('webpack') ContentBase :'./dist', port:8888, hot:true, // hotOnly:true, I also don't let it refresh the page}, plugins: [/ / using thermal module update method new webpack HotModuleReplacementPlugin ()],}Copy the code

2. Use Babel for ES6 syntax

In some cases, for example, some of the lower versions of the browser do not recognize our ES6 syntax, and the console will tell us that there is an error, so we need to do a lot of compatibility code for compatibility. Is that a hassle? Configuring Babel in WebPack gives us a lot of traversal. It automatically converts our written ES6 syntax into a language that the browser understands.

    1. Package transformation of business code
    • First download dependencies:

      NPM install --save-dev babel-loader @babel/core NPM install @babel/preset-env --save-dev // To convert ES6 syntax NPM install --save @babel/polyfillCopy the code
    1. Then configure it in webpack.config.js

      module: { rules: [ { test: /.js$/, exclude: /node_modules/, loader: ‘babel-loader’, options:{ presets: [[‘@babel/preset-env’,{// Automatically recognize the current generation need to complete syntax, instead of all introduced, // greatly reduce the size of the package. useBuiltIns:’usage’}]]}}]},

    1. Introduce Abel/Polyfill at the top of your current JS file

      import "@babel/polyfill"
      Copy the code

3. For third-party modules or UI component libraries developed by ourselves, the other way is more reasonable and does not pollute global variables

  • First download dependencies:

    npm install --save-dev @babel/plugin-transform-runtime
    
      npm install --save @babel/runtime
    
      npm install @babel/runtime-corejs2 --save
    Copy the code
  • Create the.babelrc file in the current project root directory and copy the following code

      {
          "plugins": [
           [
          "@babel/plugin-transform-runtime",
      {
      "corejs": 2,
      "helpers": true,
      "regenerator": true,
      "useESModules": false
    }
      ]
      ]
      }
    Copy the code