美文网首页前端自动化工具使用
webpack编译ES6,JSX(Vue,react)

webpack编译ES6,JSX(Vue,react)

作者: 小人物的秘密花园 | 来源:发表于2019-07-25 17:30 被阅读2次

参考

webpack4 的30个步骤打造优化到极致的 react 开发环境,如约而至
webpack
babel


配置

通过babel-loaderES6+JSX进行编译;

1.创建本地项目webpack-demo

mkdir webpack-demo
cd webpack-demo

2.在webpack-demo的根目录下创建package.json文件

npm init -y
  1. 安装webpack依赖包
npm i webpack webpack-cli webpack-dev-server --save-dev

模块说明:

  • webpack
    webpack核心

  • webpack-cli
    webpack的脚手架(启动器)

  • webpack-dev-server
    开发环境下用于实时加载依赖

4.修改package.json文件的scripts属性值,进行打包资源的配置

"scripts": {
    "dev": "webpack-dev-server --open --mode development",
    "build": "webpack --mode production"
  },

5.安装编译ES6JSX的依赖

npm i babel-loader @babel/core @babel/preset-env  @babel/plugin-transform-runtime   @babel/preset-react --save-dev

npm i @babel/polyfill @babel/runtime

模块作用:

  • @babel/core
    babel核心;

  • @babel/preset-env
    编译ES6;

  • @babel/preset-react
    转换JSX;

  • @babel/plugin-transform-runtime
    避免 polyfill污染全局变量,减小打包体积

  • @babel/polyfill:
    ES6 内置方法和函数转化垫片

6.创建webpack.config.js并在webpack.config.js中进行配置

const path = require('path');
module.exports = {
    entry: {
        app: './src/index.js'
    },
    output: {
        path: path.resolve(__dirname, 'dist'),
        filename: '[name].[hash].min.js'
    },
    module: {
        rules: [
            {
                test:/\.jsx?$/,
                exclude: /node_modules/,
                use: [{loader: 'babel-loader'}]
             }
        ]
    }
}

7.创建.babelrc,并配置.babelrc文件

{
  "presets": ["@babel/preset-env", "@babel/preset-react"],
  "plugins": ["@babel/plugin-transform-runtime"]
}

8.按需引入ployfill

.babelrc文件预设presets中使用设置babel-preset-env optionsuseBuiltins: usage | entry
usage: 仅仅加载代码中用到的 polyfill
entry: 根据浏览器版本的支持,将 polyfill 需求拆分引入,仅引入有浏览器不支持polyfill

a. 安装依赖

npm install core-js@2 @babel/runtime-corejs2 --save

b. 修改.babelrc文件

{
  "presets": [["@babel/preset-env", { "useBuiltIns": "usage" }],
              "@babel/preset-react"],
  "plugins": ["@babel/plugin-transform-runtime"]
}

不推荐使用import的方式引入@babel/polyfill,原因这种全局引入的方式会导致代码中引入不需要ployfill,从而使得打包体积增大;推荐使用修改.babelrc配置的方式

配置了按需引入 polyfill 后,用到es6以上的函数,babel会自动导入相关的polyfill,这样能大大减少 打包编译后的体积;

9.在入口文件app.js中写入js代码

let a = 0 , b = 0;

let sum = (a, b) => a+b;

async function getData() {
  let data = await sum(a,b);
  return data;
}
getData();

10.执行命令

npm run build

11.在根目录下出现一个名为dist的文件夹,该文件夹下的文件是打包后的资源文件;

编译结果

相关文章

  • webpack编译ES6,JSX(Vue,react)

    参考 webpack4 的30个步骤打造优化到极致的 react 开发环境,如约而至webpackbabel 配置...

  • react

    react简介 链接 静态编译,CoffeeScript jsx语法 react生命周期 链接 图解ES6中的...

  • 使用webpack + react 构建应用的基本流程与注意事项

    构建react应用,使用es6风格写法是最合适的。所以要使用babel进行编译,而且由于react的jsx语法自成...

  • React最快速上手教程

    不使用webpack或其他任何编译打包工具,但使用React的JSX混合语法,直接在浏览器中运行React的元件c...

  • virtual-dom的理解与实现

    首先,webpack会接住react相关的loader对源代码进行编译,将jsx语法转成js。比如下面的例子。不过...

  • React | 使用webpack构建React项目

    配置 React 项目,需要完成的工作: 1、编译 jsx,es6,scss 等资源 2、自动引入静态资源到 ht...

  • webpack vue 热部署配置

    安装依赖包 使用webpack编译vue文件,支持es6语法,至少需要的依赖包为: 编写webpack配置文件 配...

  • webapck

    webpack基本配置 vue-cli create-react-app只需要简单地配置就可以使用jsx和type...

  • react基础笔记

    配置 首先建立react项目最好是可以用webpack做配置,为了兼容jsx以及es6的语法我们需要在配置里如下书...

  • 面试题一览

    HTML与CSS HTML与CSS常用编译工具 原生js h5 React Vue ES6 javascript框...

网友评论

    本文标题:webpack编译ES6,JSX(Vue,react)

    本文链接:https://www.haomeiwen.com/subject/chphrctx.html