ES6深入认识02
结构赋值
- 数组的解构赋值
几种常见情况举例:
// 正常的解构赋值
let [ a, b, c ] = [ 1, 2, 3 ];
a // 1
b // 2
c // 3
let [foo, [[bar], baz]] = [1, [[2], 3]];
foo // 1
bar // 2
baz // 3
// 解构失败
let [ foo ] = [ ];
let [ bar, foo ] = [ 1 ];
// 不完全解构
let [ one, two, three, four, five ] = [ 1, 2, 3, 4, 5, 6, 7, 8 ];
// 解构错误, 报错
let [ one ] = 'hello world';
总结来看,大致分为四种:
- 解构成功
- 解构失败
- 不完全解构
- 解构错误
解构成功与其他三种对比可知,等号左侧的变量个数如果等于右侧的合法类型值,那么解构即成功,如果解构时,变量被赋予undefined就属于解构失败,但是不报错。如果解构时,左侧的变量个数小于右侧的合法值,则必定有一部分本应该赋值给等号右侧变量的值被浪费,而解构错误则很好理解,解构时等号右侧并非可遍历类型。
- 默认值
- 解构赋值中,在被赋值的位置严格等于undefined时才会使用默认值。示例如下:
let [ x = 1 ] = [ '' ];
let [ x = 1 ] = [ null ];
let [ x = 1 ] = [ undefined ];
以上三种案例,只有最后一种可以使x被赋值为1,其他几种情况都因等号右侧内容与undefined
不严格相等,导致默认值赋值失败
- 默认值可以引用解构赋值的其他变量,但该变量必须已经声明,示例:
let [ x = y, y = 1 ] = [ 0, 2 ]; // 报引用错误
此处就是一个典型的引用结构赋值的其他变量,导致错误的例子,在x被赋值为y的时候,y还并未被声明且也未被赋值。
promise
自己对于promise的几点理解:
- 解决方案角度:promise是一种处理异步编程的解决方案,对比传统的回调函数和事件更合理强大
- 本质:promise是一个装着未来才会结束的某一个事件的结果
- 语法:promise是一个对象,原型上有一些方法API,例如:then/catch/finally,分别用于处理返回的promise。该对象有三种状态pending/fulfilled(resolved)/rejected,平时在控制台中检查网络请求时,在请求过程中就会有接口pending的状态显示,此时表示请求进行中,而resolved表示请求完成,即对应着状态码为200,状态不为4的请求状态,rejected表示请求被拒绝,可能是因为网络问题,或者其他的错误导致。
- 特点:1. 是一个封闭的容器,它的状态变化只会根据自己的请求而变化,不受外部因素影响 2. 一旦promise的状态发生改变,就不会再变化 对比普通的事件来说,如果一旦错过事件,再去监听,就得不到结果了,比如监听点击事件,如果我们在点击事件结束之后再去监听,就无法找到对应的
e.target
究竟对应的内容是什么,这说明普通事件的结果并不会一直保存,但是promise的结果一旦改变,就会定性,一旦定性,就会保存,访问该结果时,始终能找到promise对应的状态以及结果。
基本用法尝试
ES6 规定,Promise对象是一个构造函数,用来生成Promise实例。
Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve和reject。
const promise = new Promise(function(resolve, reject) {
// ... some code
if (/* 异步操作成功 */){
resolve(value);
} else {
reject(error);
}
});
实际调用时,写为promise.then(resolve).catch(reject)
,在上面的promise异步操作成功时会触发条件判断里的resolve函数,并且操作结束之后resolve会将结果传递出来,所以可以在promise.then里面去设置resolve,此时就已经是在promise之外去接收promise的处理结果了,这就说明promise虽然是一个封闭的容器,内部状态不受外部影响,但是可以借助resolve和reject将promise返回的结果进行处理以及向外部传递。
以上then与catch的写法为最佳实践,所以之后不会使用then(resolve, reject)的回调函数形式。
promise新建之后就会立即执行
new一个promise之后,即新建一个promise之后,就会立即执行,执行过程中,遇到同步任务,会先让同步任务完成,然后再继续promise相关的异步操作,比如then里面的resolve,catch里面的reject,示例如下:
let flag = 2;
let promise = new Promise(function(resolve, reject) {
console.log('Promise');
if(flag === 1) {
resolve();
} else {
reject();
}
});
promise.then(function() {
console.log('resolved.');
}).catch(function() {
console.log('rejected');
});
console.log('Hi!');
反思:不断修改flag的值就会发现,无论怎么修改,只要一旦new完Promise之后,就会立即执行,而非在then或者catch的时候才会执行异步操作