原文地址:https://www.hangge.com/blog/cache/detail_1638.htmlhtml
2015年6月, ES2015(即 ECMAScript 六、ES6) 正式发布。其中 Promise 被列为正式规范,成为 ES6 中最重要的特性之一。数组
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
29
30
31
32
33
34
|
//作饭
function
cook(){
console.log(
'开始作饭。'
);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'作饭完毕!'
);
resolve(
'鸡蛋炒饭'
);
}, 1000);
});
return
p;
}
//吃饭
function
eat(data){
console.log(
'开始吃饭:'
+ data);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'吃饭完毕!'
);
resolve(
'一块碗和一双筷子'
);
}, 2000);
});
return
p;
}
function
wash(data){
console.log(
'开始洗碗:'
+ data);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'洗碗完毕!'
);
resolve(
'干净的碗筷'
);
}, 2000);
});
return
p;
}
|
(2)使用 then 链式调用这三个方法:promise
1
2
3
4
5
6
7
8
9
10
|
cook()
.then(
function
(data){
return
eat(data);
})
.then(
function
(data){
return
wash(data);
})
.then(
function
(data){
console.log(data);
});
|
固然上面代码还能够简化成以下:异步
1
2
3
4
5
6
|
cook()
.then(eat)
.then(wash)
.then(
function
(data){
console.log(data);
});
|
(3)运行结果以下:函数
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
|
//作饭
function
cook(){
console.log(
'开始作饭。'
);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'作饭失败!'
);
reject(
'烧焦的米饭'
);
}, 1000);
});
return
p;
}
//吃饭
function
eat(data){
console.log(
'开始吃饭:'
+ data);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'吃饭完毕!'
);
resolve(
'一块碗和一双筷子'
);
}, 2000);
});
return
p;
}
cook()
.then(eat,
function
(data){
console.log(data +
'无法吃!'
);
})
|
运行结果以下:spa
1
2
3
4
|
cook()
.then(
null
,
function
(data){
console.log(data +
'无法吃!'
);
})
|
(1)它能够和 then 的第二个参数同样,用来指定 reject 的回调rest
1
2
3
4
5
|
cook()
.then(eat)
.
catch
(
function
(data){
console.log(data +
'无法吃!'
);
});
|
(2)它的另外一个做用是,当执行 resolve 的回调(也就是上面 then 中的第一个参数)时,若是抛出异常了(代码出错了),那么也不会报错卡死 js,而是会进到这个 catch 方法中。code
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
29
30
31
32
|
//作饭
function
cook(){
console.log(
'开始作饭。'
);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'作饭完毕!'
);
resolve(
'鸡蛋炒饭'
);
}, 1000);
});
return
p;
}
//吃饭
function
eat(data){
console.log(
'开始吃饭:'
+ data);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'吃饭完毕!'
);
resolve(
'一块碗和一双筷子'
);
}, 2000);
});
return
p;
}
cook()
.then(
function
(data){
throw
new
Error(
'米饭被打翻了!'
);
eat(data);
})
.
catch
(
function
(data){
console.log(data);
});
|
运行结果以下:htm
1
2
3
4
5
6
7
8
9
10
11
|
somePromise.then(
function
() {
return
a();
}).
catch
(TypeError,
function
(e) {
//If a is defined, will end up here because
//it is a type error to reference property of undefined
}).
catch
(ReferenceError,
function
(e) {
//Will end up here if a wasn't defined at all
}).
catch
(
function
(e) {
//Generic catch-the rest, error wasn't TypeError nor
//ReferenceError
});
|
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
29
30
|
//切菜
function
cutUp(){
console.log(
'开始切菜。'
);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'切菜完毕!'
);
resolve(
'切好的菜'
);
}, 1000);
});
return
p;
}
//烧水
function
boil(){
console.log(
'开始烧水。'
);
var
p =
new
Promise(
function
(resolve, reject){
//作一些异步操做
setTimeout(
function
(){
console.log(
'烧水完毕!'
);
resolve(
'烧好的水'
);
}, 1000);
});
return
p;
}
Promise
.all([cutUp(), boil()])
.then(
function
(results){
console.log(
"准备工做完毕:"
);
console.log(results);
});
|
(2)运行结果以下:对象
1
2
3
4
5
6
|
Promise
.race([cutUp(), boil()])
.then(
function
(results){
console.log(
"准备工做完毕:"
);
console.log(results);
});
|
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
29
30
|
//请求某个图片资源
function
requestImg(){
var
p =
new
Promise(
function
(resolve, reject){
var
img =
new
Image();
img.onload =
function
(){
resolve(img);
}
img.src =
'xxxxxx'
;
});
return
p;
}
//延时函数,用于给请求计时
function
timeout(){
var
p =
new
Promise(
function
(resolve, reject){
setTimeout(
function
(){
reject(
'图片请求超时'
);
}, 5000);
});
return
p;
}
Promise
.race([requestImg(), timeout()])
.then(
function
(results){
console.log(results);
})
.
catch
(
function
(reason){
console.log(reason);
});
|
上面代码 requestImg 函数异步请求一张图片,timeout 函数是一个延时 5 秒的异步操做。咱们将它们一块儿放在 race 中赛跑。