基本介绍
ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在 2015 年 6 月正式发布了。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言。
我们从node开始,会大量用到ES6中的一些新语法,因此在学习node之前需要先学习一下es6中提供的新语法
javascript的诞生
-
1992年底,美国国家超级电脑应用中心(NCSA)开始开发一个独立的浏览器,叫做 Mosaic。这是人类历史上第一个浏览器,从此网页可以在图形界面的窗口浏览。
-
1994年10月, Netscape (网景)公司,就是在 Mosaic 的基础上,开发面向普通用户的新一代的浏览器 Netscape Navigator。
-
1994年12月,Navigator 发布了1.0版,市场份额一举超过90%。
-
Netscape 公司很快发现,Navigator 浏览器需要一种可以嵌入网页的脚本语言,用来控制浏览器行为。 因为当时网速特别的慢,很多表单的校验不适合放在服务器端进行校验。管理层对于这种脚本语言的设想是:功能不需要太强大,语法要简单,容易学习和使用
-
1995年,Netscape 公司雇佣了程序员
Brendan Eich 布兰登·艾奇
开发这种网页脚本语言。 -
1995年5月,Brendan Eich 只用了10天,就设计完成了这种语言的第一版,叫做
LiveScript
。它是一个大杂烩,语法有多个来源。- 基本语法:借鉴 C 语言和 Java 语言。
- 数据结构:借鉴 Java 语言,包括将值分成原始值和对象两大类。
- 函数的用法:借鉴 Scheme 语言和 Awk 语言,将函数当作第一等公民,并引入闭包。
- 原型继承模型:借鉴 Self 语言(Smalltalk 的一种变种)。
- 正则表达式:借鉴 Perl 语言。
- 字符串和数组处理:借鉴 Python 语言。
-
为了保持简单,这种脚本语言缺少一些关键的功能,比如块级作用域、模块、子类型(subtyping)等等,但是可以利用现有功能找出解决办法。 后果:对于其他的编程语言,你需要只需要学习该语言提供的各种语法即可。对于javascript,你需要学习解决问题的各种模式,比如原型,原型链实现继承,闭包等等
-
1995年 12月,Netscape 公司与 Sun 公司合作,后者允许将这种语言叫做 JavaScript。把LiveScript改名成了Javascript
-
注意:javascript实质上和java没有什么关系
ECMAScript与Javascript的关系
1996年11月,JavaScript 的创造者 Netscape 公司,决定将 JavaScript 提交给国际标准化组织ECMA,希望这种语言能够成为国际标准。次年,ECMA 发布 262 号标准文件(ECMA-262)的第一版,规定了浏览器脚本语言的标准,并将这种语言称为 ECMAScript ,这个版本就是1.0版。
该标准从一开始就是针对 JavaScript 语言制定的,但是之所以不叫 JavaScript ,有两个原因。一是商标,Java是 Sun 公司的商标,根据授权协议,只有 Netscape 公司可以合法地使用 JavaScript 这个名字,且 JavaScript 本身也已经被 Netscape 公司注册为商标。二是想体现这门语言的制定者是 ECMA ,不是 Netscape ,这样有利于保证这门语言的开放性和中立性。
ECMAScript,简称ES,是由Ecma国际(欧洲计算机制造商协会,英文名称是European Computer Manufacturers Association)按照标准制定的一种脚本语言规范。
JavaScript是按ECMAScript规范实现的一种脚本语言,JavaScript除了实现了ECMAScript规范,还提供了BOM和DOM的操作。
ECMAScript版本历史
-
ES1.0, 1997年06月发布
-
ES2.0, 1998年06月发布
-
ES3.0, 1999年12月发布
-
ES4.0, 由于关于语言的复杂性出现了分歧。放弃发布
-
ES5.0, 2009年12月发布, 增加了严格模式,增加了少量语法,为ES6铺路
-
ES6.0, 2015年6月发布,增加了大量的新概念和语法特性
- 第六版的名字, 可以叫做ECMAScript6.0(ES), 也可以叫做ECMAScript 2015(ES2015)
- ECMA组织决定以后每年6月份都会发布一版新的语法标准,比如ES7(ECMAScript 2016)
- 通过我们说的ES6泛指ES5之后的下一代标准,涵盖了ES6, ES7, ES8…
- 参考书籍: https://es6.ruanyifeng.com/
ES5-数组的新方法
forEach
forEach()
方法对数组的每个元素执行一次提供的函数。功能等同于for
循环.
应用场景:为一些相同的元素,绑定事件处理器!
需求:遍历数组[“张飞”,“关羽”,“赵云”,“马超”]
var arr = ["张飞","关羽","赵云","马超"];
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
arr.forEach(function(element, index, array){
console.log(element, index, array);
});
map
map()
方法创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。
需求:遍历数组,求每一项的平方存在于一个数组中
var arr = [1,2,3,4,5]; // 1 4 9 16 25
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
//返回值:一个新数组,每个元素都是回调函数的结果。
var newArray = arr.map(function(element, index, array){
return element * element;
});
console.log(newArray);//[1,4,9,16,25]
案例:获取所有的名字
filter
filter
用于过滤掉“不合格”的元素
返回一个新数组,如果在回调函数中返回true,那么就留下来,如果返回false,就扔掉
需求:遍历数组,将数组中工资超过5000的值删除[1000, 5000, 20000, 3000, 10000, 800, 1500]
var arr = [1000, 5000, 20000, 3000, 10000, 800, 1500];
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
//返回值:一个新数组,存储了所有返回true的元素
var newArray = arr.filter(function(element, index, array){
if(element > 5000) {
return false;
}else {
return true;
}
});
console.log(newArray);//[1000, 5000, 3000, 800, 1500]
some
some
用于遍历数组,如果有至少一个满足条件,就返回true,否则返回false。
需求:遍历数组,判断数组是否包含奇数,[2,4,6,8,10,9]
var arr = [2,4,6,8,10,21];
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
//返回值:布尔类型的值,只要有一个回调函数返回true,就返回true
var flag = arr.some(function(element, index, array){
console.log(element, index, array);
if(element %2 == 1){
return true;
}else {
return false;
}
});
console.log(flag);//true
every
every
用于遍历数组,只有当所有的元素返回true,才返回true,否则返回false。
需求:遍历数组,判断数组是否都是偶数,[2,4,6,8,10,9]
var arr = [2,4,6,8,