ES6入门一:ES6简介及Babel转码器

  • ES6简介
  • Babel转码器
  • Nodejs中使用ES6
  • WebPack中使用ES6及Babel转码插件

一、ES6简介与转码

 1.1一个常见的问题,ECMAScript和JavaScript到底是什么关系?

  • 1996年11月,JavaScript的创造者——Netscape公司,决定将JavaScript提交给国际标准化组织ECMA,希望JavaScript这种语言能够成为国际标准。
  • 1997年,ECMA发布262号标准文件(ECMA-262)的第一版,规定了浏览器脚本语言的标准,并将这种语言称为ECMAScript,这个版本就是ES1.0。
  • ECMA全称European Computer Manufactuers Association,翻译过来的中文名叫做“欧洲计算机制造联合会”,这个组织的目标是评估,开发和认可电信和计算机标准。始建于1961年,但是为了建立统一的电脑操作格式标准--包括程序语言和输入输出的组织。

一个常见的追问,为什么使用ECMAScript这个名称,而不是JavaScript?

  • 一是商标问题:Java是Sun公司的注册商标,根据授权协议,只有Netscape公司可以合法的使用JavaScript这个名字,而且JavaScript本身也已被Netscape公司注册为商标。
  • 二是语言所有归属问题:ECMAScript这个名称体现出这门语言的制定者是ECMA,而不是Netscape,这样有利于保证这门语言的开放性和中立性。

所以,ECMAScript和Javascript的关系是,前者是后者的规格,后者是前者的一种实现。另外ECMAScript方言还有JScript和ActionScript。

1.2ES6与ECMAScript2015的关系?

ECMAScript2015简称为ES2015。2011年ECMAScript 5.1版本发布,6.0版本开始制定,ES6这个词原意指javascript的下一个版本。但是由于这个版本引入的版本语法太多,而且制定过程中还有很多组织和个人提交新功能。因此,不可能在同一个版本里包含所有将要引进的功能。常规的做法是先发布6.0版本,然后过段时间发布6.1,6.2,6.3.....版本。但是标准委员会为了让标准升级成为常规流程,让任何人在任何时候都可以提交新语法提案,然后标准委员会每个月开一会,评估这些提案是否可以接受,需要哪些改进。经过多次会议后,如果一个提按足够成熟便可进入标准。然后,每年6月发布一次标准。

ES6第一个版本就这样在2015年6月发布,正式名称是《ECMAScript2015标准》(简称ES2015)。通常ES6被泛指为ES5.1版本的下一代标准,涵盖ES2015、ES2016、ES2017等。也有人称ES2016为ES7、ES2017为ES8,以这样的方式描述的化今年的ES2019就是ES10。

注:ECMAScript迭代的目的是为了让JS语言能用于编写复杂的大型应用程序,成为企业级开发语言。

TC39(Technical Committee 39)是一个推动JavaScript发展的委员会,github连接:https://github.com/tc39,官方网站:https://tc39.es/如有兴趣了解最新JS提案可以查看这两个网站。

欧洲计算机制造商协会官网:https://www.ecma-international.org

 1.3Babel转码器

由于浏览器还存在一些对新语法的支持,特别是在老版本的浏览器上,为了在开发中可以使用新的语法在浏览器和其他环境中可以执行,可以借助转码工具将新语法转码成ES5,来实现生产开发的统一性,但是不是所有新语法都可以被转码的。

新的语法并不改变语言的特性,只是在原有的语法基础上新增一些语法糖。只是为了增加代码的可读性,从而减少代码的出错机会。

Babel官网:https://www.babeljs.cn/

Babel在线工具:https://www.babeljs.cn/repl

配置安装及说明:

1 npm init -y //初始化项目配置(自动生成一个package.json文件)
2 npm install @babel/core --save-dev //在当前工作区间安装babel/core插件
3 npm install @babel/cli --save-dev //在当前工作区间安装babel/cli插件
4 npm install @babel/preset-env --save-dev //在当前工作区间安装babel/preset-env插件
5 npm install @babel/plyfill --save-dev //在当前工作区间安装babel/plyfill插件

@babel/core :babel核心工具包,用来将JS代码转换成抽象语法树

@babel/cli :babel手脚架,用来开启指定调用插件编译代码

@babel/preset-env:babel具体解析ES6语法的工具集合,这个集合只用来解析新的js语法,不转换新的API

@babel/plyfill :babel用来解析新的API,比如:Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比如Object.assign、Array.from)。这里有一篇使用教程:https://blog.csdn.net/qq_21294095/article/details/88812344

配置文件.babelrc

该文件用来设置转码规则和插件,基本格式如下:

1 {
2     "presets": [
3         //预设编译插件
4         "@babel/preset-env"
5     ],
6     "plugins": [
7         //引用外部编译插件
8     ]
9 }

测试babel编译:

let a = 10; //在当前工作区间下创建一个index.js文件并写入这行代码

使用bebel/cli命令编译index.js文件

npx babel index.js -o compiled.js

编译完成后会在当前工作区间下新增一个compiled.js文件,文件里面的内容如下:

1 "use strict";
2
3 var a = 10;

--watch实现时实监听编译,就是只需要编译一次后,只要在修改源文件,编译文件就会自动生成最新的代码

npx babel index.js -o compiled.js --watch

...未完待续。

原文地址:https://www.cnblogs.com/ZheOneAndOnly/p/11330342.html

时间: 2024-10-25 14:26:14

ES6入门一:ES6简介及Babel转码器的相关文章

常见的ES6转码(编译)工具——Babel转码器、Traceur转码器

在浏览器里面如何使用?现在ES6的使用也是一个新趋势,下面就来讲解转码的常见方法当ES6不兼容时,需要用到转码工具1.Babel转码器: Babel是一个广泛使用的ES6转码器,可以将ES6代码转为ES5代码,从而在现有环境执行. 这意味着,你可以用ES6的方式编写程序,又不用担心现有环境是否支持. // 转码前 input.map(item => item + 1); // 转码后 input.map(function (item) { return item + 1; }); 上面的原始代码

Babel 转码器 § es6转换es5

Babel 转码器 § es6转换es5 实时转码 /  Repl  -babel-node / babel-register(自动转码引入babel-register模块) 配置文件.babelrc 1.Babel 的配置文件是.babelrc,存放在项目的根目录下.使用 Babel 的第一步,就是配置这个文件. 该文件用来设置转码规则和插件,基本格式如下. { "presets": [], "plugins": [] } 2.presets字段设定转码规则,官方

使用babel转码器,让浏览器支持es6语法

ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,可是很多浏览器并不支持es6语法,所以我们需要一个转码工具, 把es6的语法转换成浏览器支持的javascript,Babel是一个广泛使用的ES6转码器,可以将ES6代码转为ES5代码.在babel的安装设置里我选用的是使用node 来进行安装. 1.在你的项目下输入命令: npm install --save-dev babel-core 按回车健,运行如下: 2.配置文件.babelrc 在项目根目

es6 babel转码器安装配置

例如:桌面上新建个文件夹es6,文件夹里新建一个文件es6.js.(iOS系统里安装的,windows还没安装过) 打开小黑窗进入文件夹.(windows要以管理员的方式打开cmd) 1.先全局安装babel-cli,输入命令 sudo npm install babel-cli -g (windows去掉sudo) 2.输入cd Desktop/es6 ; ---(进去文件夹) 3.输入 npm init: 一路回车键 ---(引导你创建一个package.json文件,包括名称.版本.作者这

1.Babel转码器

为什么要使用Babel? 在当代环境中虽然对ES6的支持越来越好,但是大多数还是不支持ES6,这时候我们就需要把已经写好的ES6代码转换成ES5,而Babel就是将ES6转化成ES5的转码器,被广泛使用. 举个栗子: // 转码前 input.map(item => item + 1); // 转码后 input.map(function (item) { return item + 1; }); 配置文件 .babelrc .babelrc是babel的配置文件,放在项目的根目录下,比如现有的

V9帮助手册 > 入门介绍 > 软件简介 什么是火车采集器?

什么是火车采集器? 火车采集器是一款专业的互联网数据抓取.处理.分析,挖掘软件, 可以灵活迅速地抓取网页中大量非结构化的文本,图片等资源信息, 然后通过一系列的分析处理,准确挖掘出所需数据. 并可以选择发布到网站后台.导入数据库或者保存在本地Excel,Word等格式的文件中. 火车采集器历经十年的升级更新,积累了大量用户和良好口碑,是目前最受欢迎的网页数据采集软件. 火车采集器V9程序目录 |-Configuration用户配置保存目录 |-Synonym 用户同义词保存目录 <<<&

ES6入门十二:Module(模块化)

webpack4打包配置babel7转码ES6 Module语法与API的使用 import() Module加载实现原理 Commonjs规范的模块与ES6模块的差异 ES6模块与Nodejs模块相互加载 模块循环加载 一.webpack4打包配置babel7转码ES6 1.webpack.config.js 在webpack中配置babel转码其实就是在我之前的webpack配置解析基础上添加babel的加载器,babel的具体转码配置在之前也有一篇详细的博客做了解析: webpack安装与

ES6 入门系列 - 函数的扩展

1函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法. function log(x, y) { y = y || 'World'; console.log(x, y); } log('Hello') // Hello World log('Hello', 'China') // Hello China log('Hello', '') // Hello World 上面代码检查函数log的参数y有没有赋值,如果没有,则指定默认值为World.这种写法的

ES6入门六:class的基本语法、继承、私有与静态属性、修饰器

基本语法 继承 私有属性与方法.静态属性与方法 修饰器(Decorator) 一.基本语法 1 class Grammar{ 2 constructor(name,age){ //定义对象自身的方法和属性 3 this.name = name, 4 this.age = age 5 } 6 // 在原型上定义只读属性 7 get inva(){ 8 return "JS"; 9 } 10 //在原型上定义可读写属性 11 set skill(val){ 12 this._skill =