浅谈JavaScript、ES5、ES6

释放双眼,带上耳机,听听看~!

什么是JavaScript

JavaScript一种动态类型、弱类型、基于原型的客户端脚本语言,用来给HTML网页增加动态功能。(好吧,概念什么最讨厌了)

动态:

在运行时确定数据类型。变量使用之前不需要类型声明,通常变量的类型是被赋值的那个值的类型。

弱类:

计算时可以不同类型之间对使用者透明地隐式转换,即使类型不正确,也能通过隐式转换来得到正确的类型。

原型:

新对象继承对象(作为模版),将自身的属性共享给新对象,模版对象称为原型。这样新对象实例化后不但可以享有自己创建时和运行时定义的属性,而且可以享有原型对象的属性。

PS:新对象指函数,模版对象是实例对象,实例对象是不能继承原型的,函数才可以的。

 

JavaScript由三部分组成:

1. ECMAScript(核心)

作为核心,它规定了语言的组成部分:语法、类型、语句、关键字、保留字、操作符、对象

浅谈JavaScript、ES5、ES6

PS:*不完全兼容的实现

2. DOM(文档对象模型)

DOM把整个页面映射为一个多层节点结果,开发人员可借助DOM提供的API,轻松地删除、添加、替换或修改任何节点。

PS:DOM也有级别,分为DOM1、DOM2、DOM3,拓展不少规范和新接口。

浅谈JavaScript、ES5、ES6

3. BOM (浏览器对象模型)

支持可以访问和操作浏览器窗口的浏览器对象模型,开发人员可以控制浏览器显示的页面以外的部分。

PS:BOM未形成规范

 

什么是ES5

作为ECMAScript第五个版本(第四版因为过于复杂废弃了),浏览器支持情况可看第一副图,增加特性如下。

1. strict模式

严格模式,限制一些用法,'use strict';

2. Array增加方法

增加了every、some 、forEach、filter 、indexOf、lastIndexOf、isArray、map、reduce、reduceRight方法

PS: 还有其他方法 Function.prototype.bind、String.prototype.trim、Date.now

3. Object方法

Object.getPrototypeOf

Object.create

Object.getOwnPropertyNames

Object.defineProperty

Object.getOwnPropertyDescriptor

Object.defineProperties

Object.keys

Object.preventExtensions / Object.isExtensible

Object.seal / Object.isSealed

Object.freeze / Object.isFrozen

PS:只讲有什么,不讲是什么。

 

什么是ES6

ECMAScript6在保证向下兼容的前提下,提供大量新特性,目前浏览器兼容情况如下:

浅谈JavaScript、ES5、ES6

ES6特性如下:

1.块级作用域 关键字let, 常量const

2.对象字面量的属性赋值简写(property value shorthand)


1
2
3
4
5
6
7
8
9
10
11
12
13
14
1var obj = {
2    // __proto__
3    __proto__: theProtoObj,
4    // Shorthand for ‘handler: handler’
5    handler,
6    // Method definitions
7    toString() {
8    // Super calls
9    return "d " + super.toString();
10    },
11    // Computed (dynamic) property names
12    [ 'prop_' + (() => 42)() ]: 42
13};
14

3.赋值解构


1
2
3
4
5
1let singer = { first: "Bob", last: "Dylan" };
2let { first: f, last: l } = singer; // 相当于 f = "Bob", l = "Dylan"
3let [all, year, month, day] =  /^(\d\d\d\d)-(\d\d)-(\d\d)$/.exec("2015-10-25");
4let [x, y] = [1, 2, 3]; // x = 1, y = 2
5

4.函数参数 – 默认值、参数打包、 数组展开(Default 、Rest 、Spread)


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
1//Default
2function findArtist(name='lu', age='26') {
3    ...
4}
5
6//Rest
7function f(x, ...y) {
8  // y is an Array
9  return x * y.length;
10}
11f(3, "hello", true) == 6
12
13//Spread
14function f(x, y, z) {
15  return x + y + z;
16}
17// Pass each elem of array as argument
18f(...[1,2,3]) == 6
19

5.箭头函数 Arrow functions

(1).简化了代码形式,默认return表达式结果。

(2).自动绑定语义this,即定义函数时的this。如上面例子中,forEach的匿名函数参数中用到的this。

6.字符串模板 Template strings


1
2
3
4
1var name = "Bob", time = "today";
2`Hello ${name}, how are you ${time}?`
3// return "Hello Bob, how are you today?"
4

7. Iterators(迭代器)+ for..of

迭代器有个next方法,调用会返回:

(1).返回迭代对象的一个元素:{ done: false, value: elem }

(2).如果已到迭代对象的末端:{ done: true, value: retVal }


1
2
3
4
5
1for (var n of ['a','b','c']) {
2  console.log(n);
3}
4// 打印a、b、c
5

8.生成器 (Generators)

9.Class

Class,有constructor、extends、super,但本质上是语法糖(对语言的功能并没有影响,但是更方便程序员使用)。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
1class Artist {
2    constructor(name) {
3        this.name = name;
4    }
5
6    perform() {
7        return this.name + " performs ";
8    }
9}
10
11class Singer extends Artist {
12
13    constructor(name, song) {
14        super.constructor(name);
15        this.song = song;
16    }
17
18    perform() {
19        return super.perform() + "[" + this.song + "]";
20    }
21}
22
23let james = new Singer("Etta James", "At last");
24james instanceof Artist; // true
25james instanceof Singer; // true
26
27james.perform(); // "Etta James performs [At last]"
28

10.Modules

ES6的内置模块功能借鉴了CommonJS和AMD各自的优点:

(1).具有CommonJS的精简语法、唯一导出出口(single exports)和循环依赖(cyclic dependencies)的特点。

(2).类似AMD,支持异步加载和可配置的模块加载。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
1class Artist {
2    constructor(name) {
3        this.name = name;
4    }
5
6    perform() {
7        return this.name + " performs ";
8    }
9}
10
11class Singer extends Artist {
12
13    constructor(name, song) {
14        super.constructor(name);
15        this.song = song;
16    }
17
18    perform() {
19        return super.perform() + "[" + this.song + "]";
20    }
21}
22
23let james = new Singer("Etta James", "At last");
24james instanceof Artist; // true
25james instanceof Singer; // true
26
27james.perform(); // "Etta James performs [At last]"
28

11.Map + Set + WeakMap + WeakSet

四种集合类型,WeakMap、WeakSet作为属性键的对象如果没有别的变量在引用它们,则会被回收释放掉。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
1// Sets
2var s = new Set();
3s.add("hello").add("goodbye").add("hello");
4s.size === 2;
5s.has("hello") === true;
6
7// Maps
8var m = new Map();
9m.set("hello", 42);
10m.set(s, 34);
11m.get(s) == 34;
12
13//WeakMap
14var wm = new WeakMap();
15wm.set(s, { extra: 42 });
16wm.size === undefined
17
18// Weak Sets
19var ws = new WeakSet();
20ws.add({ data: 42 });//Because the added object has no other references, it will not be held in the set
21

12.Math + Number + String + Array + Object APIs

一些新的API


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
1// Sets
2var s = new Set();
3s.add("hello").add("goodbye").add("hello");
4s.size === 2;
5s.has("hello") === true;
6
7// Maps
8var m = new Map();
9m.set("hello", 42);
10m.set(s, 34);
11m.get(s) == 34;
12
13//WeakMap
14var wm = new WeakMap();
15wm.set(s, { extra: 42 });
16wm.size === undefined
17
18// Weak Sets
19var ws = new WeakSet();
20ws.add({ data: 42 });//Because the added object has no other references, it will not be held in the set
21

13. Proxies

使用代理(Proxy)监听对象的操作,然后可以做一些相应事情。


1
2
3
4
5
6
7
8
9
10
1var target = {};
2var handler = {
3  get: function (receiver, name) {
4    return `Hello, ${name}!`;
5  }
6};
7
8var p = new Proxy(target, handler);
9p.world === 'Hello, world!';
10

可监听的操作: get、set、has、deleteProperty、apply、construct、getOwnPropertyDescriptor、defineProperty、getPrototypeOf、setPrototypeOf、enumerate、ownKeys、preventExtensions、isExtensible。

14.Symbols

Symbol是一种基本类型。Symbol 通过调用symbol函数产生,它接收一个可选的名字参数,该函数返回的symbol是唯一的。


1
2
3
4
1var key = Symbol("key");
2var key2 = Symbol("key");
3key == key2  //false
4

15.Promises

Promises是处理异步操作的对象,使用了 Promise 对象之后可以用一种链式调用的方式来组织代码,让代码更加直观(类似jQuery的deferred 对象)。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
1function fakeAjax(url) {
2  return new Promise(function (resolve, reject) {
3    // setTimeouts are for effect, typically we would handle XHR
4    if (!url) {
5      return setTimeout(reject, 1000);
6    }
7    return setTimeout(resolve, 1000);
8  });
9}
10
11// no url, promise rejected
12fakeAjax().then(function () {
13  console.log('success');
14},function () {
15  console.log('fail');
16});
17

 

总结

对于ES6,在某些方式是不是重蹈ES4的覆辙,变得复杂了;又或许几年后大家的接受能力变强了,觉得是应该这样了。我觉得还是不错的,因为它们是向下兼容的,即使复杂语法不会用,也能用自己熟知的方式,提供的语法糖也都挺实际。

这一篇幅有些长了,就到此为止了。这一篇文章旨在讲有什么,应该是包含绝大多数内容,但没有做详细分析,部分内容来自网上资料,就不一一列出了。

 

 

给TA打赏
共{{data.count}}人
人已打赏
安全技术

加密算法比较:SHA1,SHA256,MD5

2021-8-18 16:36:11

安全技术

C++ 高性能服务器网络框架设计细节

2022-1-11 12:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索