H5W3
当前位置:H5W3 > HTML5 > 正文

【前端】Promise的用法

使用ES6的Promise,一般把一个异步的函数,用Promise包一层:


var test = function(data){
return new Promise(function(resolve,reject){
try{
if(data.statue === "SUCCESS"){
resolve(data);
}else{
reject(data);
}
}catch(e){
reject(e)
}
})
}

但是我了解到,可以直接使用promise对象,可以不用它来包裹任何异步(或同步)过程:


var promise = new Promise(function(resolve,reject){
// ...
resolve(999);
})
promise.then(function(value){
console.log(value); // 999
}).catch(function(error){
console.error(error);
})

请问这种直接使用的方式,主要用在什么场景下?

回答

你说的直接使用的场景是这样?

var promise = new Promise(function(resolve,reject){
    //空实现
})

里面是空实现?那我告诉你没有这种使用场景,因为这种用法永远也不会被resolve或者reject。 所以无意义

根据问题修正:

通常也不会按你的那种写法,太啰嗦。 简写是这样的

Promise
    .resolve(999)
    //链式可能

这种用法是因为,后面可能有一系列能被(或者需要被)链式调用的操作,他们也需要一个Promise作为起始点

本文地址:H5W3 » 【前端】Promise的用法

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址