全部代码均可以再个人github上查看,每一个文件夹下都会有README.md,欢迎star: https://github.com/Jasonwang911/webpackStudyInit/tree/master/babelnode
1. webpack4对UglifyJsPlugin进行了改变,在配置文件(默认为webpack.config.js)或者package.json的执行脚本 "script"中须要指定环境,默认 mode 环境为 production 为压缩代码,配置环境中须要添加 mode: 'development', package.json中须要 --mode development 来取消压缩代码。react
2.安装babel:
准备环境 sudo npm install webpack webpack-cli -g 安装后可执行 webpack 命令
安装babel npm install @babel/core babel-loader --save-devwebpack
3.webpack 命令
webpack entry output
webpack --config <webpack.config.js> (默认是webpack.config.js 默认文件名不须要使用--config 指令)git
4.webpack同时支持 es6 module、commonjs规范、AMD规范es6
es6 module 规范:github
import sum from './sum'; export default function(a, b) { return a + b; }
commonjs 规范web
var minus = require('./minus'); module.exports = function(a, b) { return a - b; }
因为 AMD 是异步加载,因此会额外打包出文件,注意修改打包路径npm
define([ 'require', 'dependency' ], function (require, factory) { return function(a, b) { return a * b; } }) require(['./muti], function(muti){ console.log(muti(2,4)) })
1、babel-loaderjson
module: { rules: [ { test: /\.js$/, use: 'babel-loader', // include: ['./app.js'], exclude: '/node_modules/' } ] }
2、babel-preset 针对语法babel
module: { rules: [ { test: /\.js$/, use: { loader: 'bable-loader', options: { presets: ['@babel/preset-env'] } }, // include: ['./app.js'], exclude: '/node_modules/' } ] }
module: { rules: [ { test: /\.js$/, use: { loader: 'babel-loader', options: { presets: [ ['@babel/preset-env', { targets: { browsers: ['> 1%', 'last 2 versions'] } }] ] } }, // include: ['./app.js'], exclude: '/node_modules/' } ] }
{ "presets": [ ["@babel/preset-env", { "targets": { "browsers": ["last 2 version", "not ie <= 6"] } }] ] }
3、babel-plugin 针对函数和方法 arr.include new Set() Generator Map Array.from Array.prototype.includes 这些方法都没有被babel处理,因此使用babel的插件来处理
babel-polifill 全局垫片,打包后代码量大,影响全局,适合产品开发
安装: npm install babel-polyfill --save
在入口文件中使用: import 'babel-polyfill'
babel-runtime-transform 局部垫片,打包后代码量少,不污染全局,适合开发插件
安装: npm install @babel/plugin-transform-runtime --save-dev
npm install @babel/runtime --save
{ "presets": [ ["@babel/preset-env", { "targets": { "browsers": ["last 2 version", "not ie <= 6"] } }] ], "plugins": ["@babel/transform-runtime"] }