Babel(1)认识Babel
阅读文档
Babel中文网
如何写好.babelrc?Babel的presets和plugins配置解析
介绍
Babel is a JavaScript compiler.——顾名思义,Babel
就是将最新的 ES6+
语法,向后兼容,编译转化为支持各个浏览器可以运行的 javascript
代码。
Babel
编译
babel
编译经历三个阶段:解析(parse)
,转换(transform
),生成(generate
)。
注意:在升级 Babel 6.X
版本以后,所有的插件都是可插拔的(意味着transform
流程全部交给了插件去做。)。
这就意味着安装babel
之后,是不能工作的,需要配置对应的 .babelrc
文件才能发挥完整的作用。
如果想要通过Babel
完成你的代码转换,那么需要配置一些你需要的插件。
插件——plugin
plugin
就是将高级的语法转化为兼容多种浏览器的载体:
Babel
构建在插件之上,使用现有的或者自己编写的插件可以组成一个转换通道,Babel
的插件分为两种: 语法插件和转换插件。
语法插件
这些插件只允许 Babel
解析(parse) 特定类型的语法(不是转换)
转换插件
将不识别的新内置函数进行转换:转换插件会启用相应的语法插件(因此不需要同时指定这两种插件)。
将箭头函数转化为普通函数
在.babelrc
设置:
{
"presets": ["@babel/plugin-transform-arrow-functions"]
}
转换 => 生成:
// 转换前
const name = 'houfee'
let hello = `hello ${name}` let func = () => {
console.log('转化箭头函数')
} // 转换后
const name = 'houfee';
let hello = `hello ${name}`; let func = function () {
console.log('转化箭头函数');
};
可见,以上转换只转换了箭头函数,而const
和 let
却没有转化。
预设——preset
babel
将 ES6+
新语法向后兼容时,将新语法封装为多个插件转化,而不是唯一一个插件。这是你想要体验 ES6
所有的新特性(注意:语法转换只是将高版本的语法转换成低版本的,但是新的内置函数、实例方法无法转换。)时,那么你只需在.babelrc
设置:
{
"presets": ["@babel/preset-env"]
}
转换 => 生成:
// 转换前
const name = 'houfee' let hello = `hello ${name}` let func = () => {
console.log('转化箭头函数')
} class Point {
constructor(x, y) {
this.x = x;
this.y = y;
}
} let promise = new Promise((res, rej) => console.log(res, rej)) // 转换后
"use strict"; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var name = 'houfee';
var hello = "hello ".concat(name); var func = function func() {
console.log('转化箭头函数');
}; var Point = function Point(x, y) {
_classCallCheck(this, Point); this.x = x;
this.y = y;
}; var promise = new Promise(function (res, rej) {
return console.log(res, rej);
});
可见: @babel/preset-env
插件只是转换了已存在的语法,对于新增的内置函数依然是无法转换的。
plugin
和 preset
关系
plugin
插件功能单一,只能完成特定语法转换;——特点是:颗粒度小,效率高,但是需要逐个引入(babel
的插件有20+)。
preset
将一系列的 plugin
功能集合在一起;——特点是:一次引入多个语法功能的插件,优化配置。
plugin
和 preset
的执行顺序
多个Plugin
和Preset
时执行顺序非常重要:
1,先执行完所有Plugin
,再执行Preset
。
2,多个Plugin
,按照声明次序顺序执行。
3,多个Preset
,按照声明次序逆序执行。
Babel
相关模块简要说明
Babel
的模块那么多,那么要怎么学习呢?
目前 Babel
版本为 Babel 7.4.0
,此图只是示意(网图~)。
核心库 @babel/core
babel
的核心 api
都在这个模块中。也就是这个模块会把我们写的 js
代码抽象成 AST
(abstract syntax tree
)树;然后再将 plugins
转译好的内容解析为 js
代码。
命令行工具 @babel/cli
babel
提供的命令行工具,主要是提供 babel
这个命令,适合安装在项目里。
@babel/node
提供了 babel-node
命令,但是 @babel/node
更适合全局安装,不适合安装在项目里。
npm install --save-dev @babel/core @babel/cli
@babel/preset-env
将新增的ES6
语法转换为浏览器支持的语法,但是不会转换新增的内置函数。
@babel/polyfill
babel
对一些新的 API 是无法转换,比如 Generator、Set、Proxy、Promise
等全局对象,以及新增的一些方法:includes、Array.form
等。所以这个时候就需要一些工具来为浏览器做这个兼容。
官网的定义:babel-polyfill
是为了模拟一个完整的 ES6+
环境,旨在用于应用程序而不是库/工具。
@babel/polyfill
主要有两个缺点:
使用
@babel/polyfill
会导致打出来的包非常大,很多其实没有用到,对资源来说是一种浪费。@babel/polyfill
可能会污染全局变量,给很多类的原型链上都作了修改,这就有不可控的因素存在。
因为上面两个问题,在 Babel7
通过设置 "useBuiltIns":"usage"
这个参数值就可以实现按需加载。
@babel/plugin-transform-runtime
配合其他插件使用,避免编译后的代码中出现重复的帮助程序,有效减少包体积。
其他预设
@babel/preset-flow
@babel/preset-react
@babel/preset-typescript
Babel(1)认识Babel的更多相关文章
- Babel插件:@babel/plugin-transform-runtime
一 概述 每个Babel编译后的脚本文件,都以导入的方式使用Babel的帮助函数,而不是每个文件都复制一份帮助函数的代码. 1 优点 (1)提高代码重用性,缩小编译后的代码体积. (2)防止污染全局作 ...
- @babel/runtime 和 @babel/plugin-transform-runtime 两个的作用是什么
Babel 最基础的功能就是将采用 ECMAScript 2015+ 语法编写的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中. 最基础的依赖包也就是 ...
- 【Babel】293- 初学 Babel 工作原理
戳蓝字「前端技术优选」关注我们哦! 前言 babel Babel 对于前端开发者来说应该是很熟悉了,日常开发中基本上是离不开它的. 已经9102了,我们已经能够熟练地使用 es2015+ 的语法.但是 ...
- Sublime插件支持Sass编译和Babel解析ES6 & .sublime-build文件初探
用Sublime Text蛮久了,配置配来配去的,每次换电脑都得重头再配过,奈何人老了脑子不中用了,得好好整理一些,下次换电脑就有得参考了.. 同事说,他的WebStorm简直太方便,自身集成了很多方 ...
- Babel 学习
一,为了更明白地使用Babel, 先了解Babel 的发展过程. 现在Babel的版本是6, 相对于以前的版本, 它做了重大更新: 1, 模块化:所有的内部组件都变成了单独的包.打开Babel在Git ...
- 深入浅出ES6(九):学习Babel和Broccoli,马上就用ES6
作者 Jason Orendorff github主页 https://github.com/jorendorff 现在,我们将向你分步展示如何做到的这一切.上面提及的工具被称为转译器,你可以将它 ...
- babel安装
大家都知道目前ES6不是浏览器全部都是支持的,所以要通过转码器先进行转码然后再编译代码.小心在学习ES6之前先安装了babel转码器,虽然当时安装的时候困难重重,遗憾的是没有把解决方案总结一下,别人询 ...
- ES6学习(1)——如何通过babel将ES6转化成ES5
使用babel编译ES6 babel是一个工具,可以通过多个平台,让js文件从ES6转化成ES5,从而支持一些浏览器并未支持的语法. Insall babel $ sudo npm install b ...
- 深入浅出 ES6:ES6 与 Babel / Broccoli 的联用
深入浅出 ES6指的是添加在 ECMASript 标准第六版中的 JavaScript 编程语言的新特性,简称为 ES6. 虽然 ES6 刚刚到来,但是人们已经开始谈论 ES7 了,它未来的样子,以及 ...
- Babel 相关资料
Babel online editor Babel Plugin Handbook babeljs usage options
随机推荐
- 字符串NSString与NSMutableString常用方法
NSString 1.初始化 NSString *str1 = @"a OC Program"; 2.初始化 NSString *str2 = [[NSString alloc] ...
- 一 注册功能&登录功能,权限拦截
注册功能: 前端JSP:提供表单注册信息以及访问路径,发送请求到Strus2. Struts2 : 通过模型驱动接收并封装User对象,Spring依赖注入(无参构造+setter方法)获取业务层Us ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 按钮:按钮被点击
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 十二、js去掉空格_比较字符长度_中英文判断_页面初始化_简体字与繁字体判断
1.去掉字符串前后所有空格 function trimBlank(str){ return str.replace(/(^\s*)|(\s*$)/g, ""); } 2.字符串长度 ...
- 六、java基础-单例模式_继承_覆盖_多态
1.单例模式: 1)提出原因 是由gof 也就是四人组提出来的.为了保证jvm中某一类型的java对象永远只有一个,同时也是为了节省内存的开销.因为外面程序可以通过new的方法直接调用类里面的构造方法 ...
- mysql安装到最后一步无响应的问题超简单最有效解决
mysql安装到最后一步无响应的问题超简单最有效解决 无论你是安装过还是没安装过,通过此方法都可以解决.之前我的机器和服务器就是都到最后一步卡住,上网搜索方法都无果.后自己尝试了很多次,亲测64位机和 ...
- 第二章:windows下搭建开发环境
IDE ---- pycharm数据库 --- mysql.redis.elasticsearch开发环境 -- anaconda 第一节:pycharm的安装和简单使用...(网上一搜一大堆,所以没 ...
- MyBatis Dao层的编写
传统的dao层编写 以前编写dao层,先新建一个包com.chy.dao,再写接口StudentDao: public interface StudentDao { public void inser ...
- Spark 读 Hive(不在一个 yarn 集群)
方法一 1. 找到目标 Hive 的 hive-site.xml 文件,拷贝到 spark 的 conf 下面. 在我的情况下 /etc/hive/conf/hive-site.xml -> / ...
- DotNet中的继承,剖析面向对象中继承的意义
继承是面向对象程序设计不可缺少的机制,有了继承这个东西,可以提高代码的重用,提高代码的效率,减轻代码员的负担. 面向对象三大特性:封装.继承.多态是相辅相成的.封装为了继承,限制了父类的哪些成员被子类 ...