在现代前端开发中,Babel、polyfill(如 core-js)和 Loader 是非常常见又容易混淆的几个概念。为了彻底搞明白它们的作用、关系和使用方法,下面一篇文章详细梳理。
一、Babel的作用
Babel 是一个 JavaScript 的编译器,主要作用是:
把新版本 JavaScript(比如 ES6、ES2020、ES2023)代码,转换成向后兼容的老版本(比如 ES5),从而能在老浏览器或者老环境中正确运行。
Babel主要做两件事:
-
转译新语法:比如箭头函数、class、async/await等,转成老版JS写法。
-
配合polyfill补充新API:比如 Promise、Map、Set 等,在环境不支持时提供替代实现。
示例:Babel转译
比如箭头函数:
const add = (a, b) => a + b;
转译后变成普通函数:
var add = function(a, b) {
return a + b;
};
再比如类:
class Person {
constructor(name) {
this.name = name;
}
}
Babel会转成传统构造函数和原型链的形式。
二、@babel/polyfill与core-js
为了让老环境支持新的内置对象和方法 ,仅仅转语法还不够,还需要polyfill垫片。
1. @babel/polyfill(已废弃)
-
以前的解决方案,打包所有的新API补丁,比如 Promise、Array.includes、Object.assign 等。
-
缺点是体积大,哪怕只用一两个新功能,也全量引入。
👉 现在已经废弃,不推荐使用。
2. core-js
-
核心 polyfill 库,支持按需引入,比如只补 Promise 或只补 Array.includes。
-
配合 Babel 使用,更轻量、灵活。
示例:按需引入
比如只用到了 Promise
和 Array.includes
:
import "core-js/es/promise";
import "core-js/es/array/includes";
这样就不会无脑打包全部polyfill,减小体积,提升性能。
三、Babel + core-js实战配置
在实际项目中,可以这样配置 Babel + core-js:
-
安装依赖:
npm install core-js
npm install --save-dev @babel/preset-env -
配置
.babelrc
文件:{
"presets": [
[
"@babel/preset-env",
{
"useBuiltIns": "usage",
"corejs": 3
}
]
]
}
配置说明:
-
"useBuiltIns": "usage"
:自动检测代码中用到的新API,按需引入polyfill。 -
"corejs": 3
:指定使用 core-js@3 版本。
这样可以做到: ✅ 只转需要的新语法
✅ 只补需要的新API
✅ 最小化打包体积
四、Babel和Loader的关系
Babel 是真正做转译工作的编译器 ,而在打包工具(如webpack)中,要靠Loader来配合。
二者关系总结
Babel | Loader(比如babel-loader) |
---|---|
负责转译代码 | 负责让webpack认识文件并交给babel处理 |
是编译器 | 是中间桥梁 |
流程示意
webpack(打包器)
|
遇到 .js 文件
|
调用 babel-loader(Loader)
|
babel-loader 调用 Babel(Compiler)
|
Babel 把新JS → 老JS
|
返回给 webpack 继续打包
示例:webpack配置babel-loader
module.exports = {
module: {
rules: [
{
test: /\.js$/, // 处理所有.js文件
exclude: /node_modules/, // 排除node_modules
use: {
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env'] // 指定preset
}
}
}
]
}
};
五、整体流程总结(图)
-
写新语法的JS代码(ES6+)
-
webpack根据配置遇到
.js
文件,交给babel-loader处理 -
babel-loader 调用 Babel
-
Babel根据 preset-env 规则:
-
转译新语法
-
按需引用 core-js 提供的新API polyfill
-
-
转译后的老版JS交给webpack继续打包
-
输出兼容的JS文件,能在各种浏览器环境正常运行
结语
-
Babel 负责"翻译"新语法。
-
core-js 负责"补课"新功能。
-
Loader 负责"搭桥"让打包器和Babel沟通。