乐趣区

webpack4系列教程(七):使用 babel-loader

1. 什么是 Babel
如今 ES6 语法在开发中已经非常普及,甚至也有许多开发人员用上了 ES7 或 ES8 语法。然而,浏览器对这些高级语法的支持性并不是非常好。因此为了让我们的新语法能在浏览器中都能顺利运行,Babel 应运而生。Babel 是一个 JavaScript 编译器,能够让我们放心的使用新一代 JS 语法。比如我们的箭头函数:
() => console.log(‘hello babel’)
经过 Babel 编译之后:
(function(){
return console.log(‘hello babel’);
});
会编译成浏览器可识别的 ES5 语法。
2. 在 webpack 中使用 babel-loader
安装:
npm install -D babel-loader @babel/core @babel/preset-env webpack
修改 webpack.config.js,加入新的 loader:
{
test: /\.js$/,
loader: ‘babel-loader’,
exclude: /node_modules/
}
遇到 JS 文件就先用 babel-loader 处理,exclude 表示排除 node_modules 文件夹中的文件。loader 的配置就 OK 了,可是这样还不能发挥 Babel 的作用。在项目根目录下创建一个 .babelrc 文件,添加代码:
{
“presets”: [
“@babel/preset-env”
]
}
我们还希望能够在项目对一些组件进行懒加载,所以还需要一个 Babel 插件:
npm i babel-plugin-syntax-dynamic-import -D
在 .babelrc 文件中加入 plugins 配置:
{
“presets”: [
“@babel/preset-env”
],
“plugins”: [
“syntax-dynamic-import”
]
}
在 src 目录下创建 helper.js:
console.log(‘this is helper’)
再来修改我们的 main.js:
import ‘babel-polyfill’
import Modal from ‘./components/modal/modal’
import ‘./assets/style/common.less’
import _ from ‘lodash’
const App = function () {
let div = document.createElement(‘div’)
div.setAttribute(‘id’, ‘app’)
document.body.appendChild(div)
let dom = document.getElementById(‘app’)
let modal = new Modal()
dom.innerHTML = modal.template({
title: ‘ 标题 ’,
content: ‘ 内容 ’,
footer: ‘ 底部 ’
})
let button = document.createElement(‘button’)
button.innerText = ‘click me’
button.onclick = () => {
const help = () => import(‘./helper’)
help()
}
document.body.appendChild(button)
}
const app = new App()
console.log(_.camelCase(‘Foo Bar’))
当 button 点击时,加载 helper 然后调用。打包之后可见:多了一个 3.bundle.js,在浏览器打开 dist/index.html,打开 network 查看,3.bundle.js 并未加载:当点击 button 之后,发现浏览器请求了 3.bundle.js,控制台也打印出了数据。
由于 Babel 只转换语法 (如箭头函数),你可以使用 babel-polyfill 支持新的全局变量,例如 Promise、新的原生方法如 String.padStart (left-pad) 等。
安装:
npm install –save-dev babel-polyfill
在入口文件引入就可以了:
import ‘babel-polyfill’

本人才疏学浅,不当之处欢迎批评指正。

退出移动版