《前端之路》之 Babel 下一代 JavaScript 语法编译器
写本章的内容的出发点主要是 为了对于之前关于 JS 版本的一个总结,在之前的开发中,我们始终对于 ECMAScript 的版本的更新不够重视,以至于在后面的 开发过程中,我们始终会被各种新奇的语法打断了我们的思考思路,所以对于基础的追求,是任何时候都不能忘记的。不然会的框架再多,会玩儿的花样再多,到头来都只是API 。
另外 一个目的就是想做一个好玩的东西,就是 实时编译所写的高版本(ES2015+)的 JS 代码。转化成现在大部分浏览器可以兼容的 ES5 、 ES3 等。
下面就正式介绍下 Babel (v7.0.0 )
一、什么是 Babel
Babel 是一个 JavaScript 编译器,Babel 通过语法变换器支持最新版本的 JavaScript。
1-1 使用方法:
Babel 工具链中有很多工具可以让你轻松使用 Babel,无论你是“终端用户”还是构建中集成 Babel。本文是快速使用这些工具的指南,你可以在文档的“用法”部分中阅读有关它们的更多信息。
1-1-1 : CLI 用法
这里介绍到的 cli 的用法其实对于大部分同学来说不是常规用法。
因为这种用法往往出现在 各种 npm 的包、cli 构建工具集成当中,所以这里,我们只介绍下它的核心用法。
下载核心包 @babel/core
npm install --save-dev @babel/core
你可以直接在 JavaScript 中 require 它并像下面这样使用它
const babel = require("@babel/core");
babel.transform("code", optionsObject);
作为终端用户,你可能希望安装其他工具作为 @babel/core 的接口,并能很好地集成在你的开发过程中。即便如此,你仍可能需要查看其文档页面以了解这些选项,其中大部分选项也可以通过其他工具进行设置。
1-1-2 :Plugins & Presets 用法
以插件 和 预处理 的方式,是我们在开发过程中更为常见的方式。
通常我们在 Vue 项目开发中使用的是 Plugins 的方式
在 React 项目开发中使用的是 Presets 的方式 下面的文章中,我们分别来介绍 如何来使用。
1-1-3 :Polyfill
@babel/polyfill 模块包括 core-js 和自定义 regenerator runtime 来模拟完整的 ES2015+ 环境。
利用 Polyfill 更多的是来解决一个 浏览器的兼容 高版本的 ES 问题。但是往往因为这个包比较的大,所以还是慎重使用。
二、 React、Vue 结合 Babel
如何在 React、Vue 项目中结合Webpack 使用 Babel
2-1 、React && Babel
上文中有介绍到 babel 配合 React 等使用方法。--- Presets。
预处理方案。
2-1-1: 如何使用
我们配置完 webpack 和 React ,并启动 server。
这个时候我们看下我们 react 的代码
import React from "react";
import ReactDom from "react-dom";
const App = () => {
return (
<div>
<h2>hhhh</h2>
</div>
);
};
ReactDom.render(<App />, document.getElementById("apps"));
这是一个最简单的 react 的 demo 代码展示:
结果我们发现,我们的终端 上显示 ERROR:
ERROR in ./src/index.js 6:4
Module parse failed: Unexpected token (6:4)
You may need an appropriate loader to handle this file type.
| const App = () => {
| return (
> <div>
| <h2>hhhh</h2>
| </div>
@ multi (webpack)-dev-server/client?http://localhost:8081 (webpack)/hot/dev-server.js ./src main[2]
TIPS: 这个时候大多数人看到这个 error 的时候其实都是懵逼的,特别对于新手到讲,然后一部分机智的小伙子发现 已经超过了自己的 知识范围了,就去 谷歌、百度去寻求帮助
不出意外,搜索引擎统一给出的答案就是 未配置 babel 的预处理,导致 webpack 无法读懂这个代码是什么意思。
这个时候,我们来试着配置下我们的 babel 的 presets. 但是如何配置呢?
上文中,我们只是简单的介绍了下,但是实际配置的文件应该是什么样子呢?
2-1-1-1 babel 配置的第一种配置方式:
根目录创建
babel.config.js
文件。
module.exports = function() {
const presets = [];
const plugins = [];
return {
presets,
plugins
};
};
babel.config.js 的官方文档在这里 babel
2-1-1-2 babel 配置的第二种配置方式:
根目录创建
.babelrc
文件 ( JSON 格式)。
{
"presets": [],
"plugins": [],
"env": {}
}
2-1-1-3 两种配置方式的方式都是大同小异 主要是配置的内容
下一个小节我们就详细介绍下 babel的
plugins
和presets
解析
2-1-2: babel的plugins
和presets
解析
2-1-2-1:明确 ES201x 和 ESx 的关系
ES2015 =》 ES6
ES2016 =》 ES7
ES2017 =》 ES8
在 2015 年之前 ES3 是主流。
2-1-2-2:plugin
: babel的
插件
,在6.x版本之后babel必需要
配合插件来进行工作
{
"plugins": ["transform-es2015-arrow-functions"]
}
顾名思义, 这个插件就是为了编译 es6 的箭头函数
2-1-2-3:preset
: babel
插件集合的预设
,包含某一部分的插件plugin
{
"presets": ["es2015"]
}
这里着重解释下
presets
中es2015
是什么意思?
es2015 => babel-preset-es2015 (可以将 es6 的 JS 代码编译为 es5)
es2016 => babel-preset-es2016 (可以将 es7 的 JS 代码编译为 es6)
es2017 => babel-preset-es2017 (可以将 es8 的 JS 代码编译为 es7)
stage-x => babel-preset-stage-x (可以将处于某一阶段的js语法编译为正式版本的js代码)
这里再介绍下 stage-x, 提案共分为五个阶段:
- stage-0: 稻草人-只是一个大胆的想法
- stage-1: 提案-初步尝试
- stage-2: 初稿-完成初步规范
- stage-3: 候选-完成规范和浏览器初步实现
- stage-4: 完成-将被添加到下一年发布
2-1-2-4:preset env
当前 babel 推荐使用
babel-preset-env
替代 babel-preset-es2015 和 babel-preset-es2016 以及 babel-preset-es2017 ,env的支持范围更广
,包含es2015 es2016 es2017的所有语法编译
,并且它可以根据项目运行平台的支持情况自行选择编译版本
。
使用方法:
{
"presets": ["env", "stage-2"]
}
2-1-2-5: 插件中每个访问者都有排序问题
这意味着如果两次转译都访问相同的”程序”节点,则转译将按照 plugin 或 preset 的规则进行排序然后执行。
- Plugin 会运行在 Preset 之前。
- Plugin 会从第一个开始顺序执行。ordering is first to last.
- Preset 的顺序则刚好相反(从最后一个逆序执行)。
2-1-2-6: 总结:
上面项目的跑起来的时候依然还是还有bug,下面就需要我们来完善这一个问题,用上面学习到的内容
{
"presets": ["env", "stage-1", "react"],
"plugins": [
["transform-runtime", { "polyfill": false }],
"transform-decorators-legacy"
]
}
每一部分的 插件也好,预处理文件也好。都会影响着整个项目,很多时候均为 各个不同版本插件之间的兼容性问题,搞的非常头痛,所以,看准插件,仔细阅读其文档是不可或缺的。
2-2 、Vue && Babel
Vue 的话,因为有 vue-cli 的存在,已经讲
.babelrc
文件已经给用户配置好了
{
"presets": ["es2015", "stage-2"],
"plugins": ["transform-runtime"],
"comments": false
}
三、Babel 使用 总结
Babel 的使用,是我们对于 ES 的各种版本 的理解更好的帮助,在我们实际的项目使用中也提供了 更多了可能。 在结合 webpack 使用的时候,presets、plugins 的配置。tips: 配置中 各个版本之间的兼容问题得异常注意。 好了,关于 babel 相关的 介绍和理解就到这里,如果还有什么疑惑
《前端之路》之 Babel 下一代 JavaScript 语法编译器的更多相关文章
- Babel:下一代Javascript语法编译器
定义 Babel是一个Javascript的编译器,通过它你可以将一些新版本的ECMAScript语法转换成低版本的语法.以便能够在低版本的浏览器或者其它环境平稳运行. 截至目前笔者写这篇文章的时候, ...
- 用于编写下一代JavaScript的编译器。
下载 用于编写下一代JavaScript的编译器. 支持巴别塔 Babel(发音为babble)是一个由社区驱动的项目,被许多公司和项目使用,由一群志愿者维护.如果你愿意帮助支持这个项目的未来,请考虑 ...
- 一分钟入门 Babel(下一代 JavaScript 语法的编译器)
简单来说把 JavaScript 中 es2015/2016/2017/2046 的新语法转化为 es5,让低端运行环境(如浏览器和 node )能够认识并执行.严格来说,babel 也可以转化为更低 ...
- 《前端之路》之 初识 JavaScript
01 初识 JavaScript 作为在码农圈混迹了 四五年的老码畜来说,学习一门新的语言,就仿佛是老司机开新车一样 轻车熟路. 为什么会这么快呢? 因为各种套路啊- 任何一种计算机语言的最开始都是和 ...
- 《前端之路》之 Javascript 模块化管理的来世今生
目录 第二章 - 04: Javascript 模块化管理的来世今生 一.什么是模块化开发 1-1.模块化第一阶段 1-2.封装到对象 1-3. 对象的优化 二.模块化管理的发展历程 2-1.Comm ...
- JavaScript学习之路-为什么要学习JavaScript语法
版权声明:未经博主允许不得转载 前言 为什么要学习JavaScript语法,没有理由,因为工作需要,也为了成为全栈,那现在还是好好努力学习吧! 发展 说实话,JavaScript很好学也很重要,也很容 ...
- JavaScript 语法:松软科技前端教程
JavaScript 语法是一套规则,它定义了 JavaScript 的语言结构. var x, y; // 如何声明变量 x = 7; y = 8; // 如何赋值 z = x + y; // 如何 ...
- 前端之路(二)之JavaScript:菜鸟教程学习:http://www.runoob.com/js/js-intro.html
JavaScript 语句和 JavaScript 变量都对大小写敏感. 键值对通常写法为 name : value (键与值以冒号分割). 键值对在 JavaScript 对象通常称为 对象属性. ...
- web前端学习(四)JavaScript学习笔记部分(2)-- JavaScript语法详解
2.1.Javascript语法-运算符(1) 复数运算符 %取余 ++ -- 赋值运算符 += -= *= /= %= 字符串操作 <!DOCTYPE html> <html la ...
随机推荐
- Java开源生鲜电商平台-盈利模式详解(源码可下载)
Java开源生鲜电商平台-盈利模式详解(源码可下载) 该平台提供一个联合买家与卖家的一个平台.(类似淘宝购物,这里指的是食材的购买.) 平台有以下的盈利模式:(类似的平台有美菜网,食材网等) 1. 订 ...
- yii2实战之初见端倪
PHP框架大PK php框架有很多种,在国内应用较多的有:Thinkphp, Yii, Laravel, Codeigniter等.关于这些框架,孰优孰劣,是一个极具争议性的话题.各方支持者总能拿出自 ...
- python爬虫入门(八)Scrapy框架之CrawlSpider类
CrawlSpider类 通过下面的命令可以快速创建 CrawlSpider模板 的代码: scrapy genspider -t crawl tencent tencent.com CrawSpid ...
- C# 获取当前年份的周期,周期所在日期范围
最近有一个项目要用到年份周期,用于数据统计图表展示使用,当中用到年份周期,以及年份周期所在的日期范围.当初设想通过已知数据来换算年份周期,经过搜索资料发现通过数据库SQL语句来做,反而更加复杂.现在改 ...
- 回忆一下我的运维时期 关于Impact的架构服务器集群
Impact EDMP平台 Email Direct Marketing Platfrom 电子邮件营销平台 EDM 是 Email Direct Marketing 的缩写,即电子邮件营销,简 ...
- 接口调用(发送http请求)
// 向对应的url地址发送http请求, 并获取响应的json字符串 public String getHttpResponse(String url) { // result用 ...
- shell 常用命令语法简介
一.grep用法 ************************************** ++++++用一些特殊的函数来处理参数++++++ *$# 传递给函数的参数个数 *$* 显示所有传递给 ...
- SSM-Spring-06:Spring的自动注入autowire的byName和byType
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- di的注入上次讲了一些,这次主要阐述域属性的自动注入 先讲byType方式 看名字就知道是根据类型进行自动注入 ...
- Spring Webflux: Kotlin DSL [片断]
原文链接:https://dzone.com/articles/spring-webflux-kotlin-dsl-snippets 作者:Biju Kunjummen 译者:Jackie Tang ...
- REST风格框架实战:从MVC到前后端分离(附完整Demo)
既然MVC模式这么好,难道它就没有不足的地方吗?我认为MVC至少有以下三点不足:(1)每次请求必须经过“控制器->模型->视图”这个流程,用户才能看到最终的展现的界面,这个过程似乎有些复杂 ...