![大前端三剑客:Vue+React+Flutter](https://wfqqreader-1252317822.image.myqcloud.com/cover/145/47216145/b_47216145.jpg)
2.2 Babel转码器
目前大部分浏览器已经很好地支持了ES6,但是仍然存在一些浏览器支持及兼容性问题,目前,各大浏览器对ES6的支持可以查看kangax.github.io/compat-table/es6/。
为了让开发人员使用ES6标准开发的代码能够在各种浏览器端进行运行,可以使用Babel工具把ES6+代码降级到ES5版本,这样在ES6过渡阶段可以完美地兼容各种浏览器。
Babel是一个工具链,主要用于将采用ECMAScript 6+语法编写的代码转换为向后兼容的JavaScript语法,以便能够运行在当前和旧版本的浏览器或其他环境中。下面列出了Babel能做的事情。
(1)语法转换。
(2)通过Polyfill方式在目标环境中添加缺失的特性(通过引入第三方Polyfill模块,例如core-js)。
(3)源码转换(codemods)。
代码示例2-1中的原始代码用了箭头函数,Babel将其转换为普通函数,这样就能在不支持箭头函数的JavaScript环境执行了。
代码示例2-1
![](https://epubservercos.yuewen.com/467996/26580996409099006/epubprivate/OEBPS/Images/Figure-P27_1146.jpg?sign=1738794958-dNtCGeZT7z1NxAjAL5legF7S3rrN23dy-0-3486c7fe29b381ee3a4decf701958f7d)
1.命令行转码
Babel提供了命令行工具@babel/cli,用于命令行转码。它的安装命令如下:
![](https://epubservercos.yuewen.com/467996/26580996409099006/epubprivate/OEBPS/Images/Figure-P28_1160.jpg?sign=1738794958-8cjvmDVLrWzTjyQ2OYErbVgTRTH6xWUV-0-114e30292e0f2d122c5c3870054f4150)
基本用法如下:
![](https://epubservercos.yuewen.com/467996/26580996409099006/epubprivate/OEBPS/Images/Figure-P28_1168.jpg?sign=1738794958-5s3rzCKtsc0vGubYyh68Hcbt21YYrrds-0-fbb81d3311b8bb19b66a6e9f904990b7)
注意:npx可以在项目中直接运行指令,当直接运行node_modules中的某个指令时,不需要输入文件路径./node_modules/.bin/babel--version,可以直接执行npx babel--version指令。
2.Node环境支持ES6
@babel/node模块的babel-node命令提供了一个支持ES6的REPL环境。它支持Node的REPL环境的所有功能,而且可以直接运行ES6代码。
首先安装这个模块,命令如下:
![](https://epubservercos.yuewen.com/467996/26580996409099006/epubprivate/OEBPS/Images/Figure-P28_1177.jpg?sign=1738794958-FJoxiPWibpBPBaz99LBnp7v5scj0LSsM-0-8019c49df9466a08326c9b577f717740)
在项目根目录创建文件babel.config.js,文件内容如下:
![](https://epubservercos.yuewen.com/467996/26580996409099006/epubprivate/OEBPS/Images/Figure-P28_1185.jpg?sign=1738794958-ftSzpr9MGvgQF9k1GkUYdG6k7Y3lexaJ-0-35ea2d056055bb23575e4092f1c550a7)
然后执行babel-node就可进入REPL环境。命令如下:
![](https://epubservercos.yuewen.com/467996/26580996409099006/epubprivate/OEBPS/Images/Figure-P29_1198.jpg?sign=1738794958-ME3pncBpU2H71MHfJbP3X6QLVvkIHiWS-0-dc6c6f7e31a355540624858417364b97)
使用babel-node替代node,这样ES6脚本本身就不用进行任何转码处理了,但是babel-node仅用于测试,不要在生成环境中使用。