1.Promise对象

Promise 对象用于表示一个异步操作的最终完成 (或失败)及其结果值。其作用是为了解决回调地狱

回调地狱:回调函数的结果作为下一个回调函数的参数时,产生回调链,也称之为回调地狱。

例如:通过请求获取用户ID,再通过ID获取用户名,在通过用户名获取用户年龄

$.ajax({
type: "GET",
url: "test.json",
dataType: "json",
success: function(data){
let {id}=data
$.ajax({
type: "GET",
url: "test.json",
data:{id:id},
dataType: "json",
success: function(data){
let {useName}=data
$.ajax({
type: "GET",
url: "test.json",
data:{useName:useName},
dataType: "json",
success: function(data){
let {msg}=data
}
);
}
);
}
);

由于ajax是异步请求,只能等请求获取到数据之后,变量才能被赋值作为下次请求的数据,因此只能放在ajax请求内部在发送请求,此时就构成了回调地狱。

2.Promise的使用

promise是一个构造函数,可以通过new来获取Promise对象

new Promise((resolve,reject)=>{})

参数是一个回调函数,回调函数有两个参数:

resolve:修改状态为成功的函数

reject:修改状态为拒绝的函数

首先打印promise对象

promise有两个重要的属性:

state:promise对象的状态

result:promise返回结果

3.promise的状态

promise有三个状态

pending:待执行

fulfilled:已完成

rejected:已拒绝

而修改状态是通过resolve()和reject()来修改的

<script>
var p=new Promise((resolve,reject)=>{
resolve()
})
var p2=new Promise((resolve,reject)=>{
reject()
})
console.log(p);
console.log(p2);
</script>

注意:promise的状态一旦被改变将无法再进行修改

var p=new Promise((resolve,reject)=>{
resolve()
reject()
})

状态是已完成,在调用reject函数也无法再进行修改。

4.promise的结果

promise的结果主要是通过promise对象参数的回调函数的两个参数的参数决定的

resolve(result):修改状态为已完成,并将promise的结果赋值为result
reject(error):修改状态为已拒绝,并将promise的结果赋值为error
   <script>
const p= new Promise((resolve, reject) => {
resolve("成功结果")
})
const p2= new Promise((resolve, reject) => {
reject("失败结果")
})
console.log(p);
console.log(p2);
</script>

5.promise的then方法

then方法接收两个参数,两个参数都是一个回调函数

  • 第一个参数为回调函,表示状态为已完成的时候调用,该回调函数结构resolve函数的参数作为参数
  • 第二个参数为回调函数,表示状态为已拒绝的时候调用,该回调函数结构reject函数的参数作为参数
<script>
const p= new Promise((resolve,reject)=>{
let a="qq"
resolve(a)//resolve函数调用相当执行了then方法的第一个参数回调函数
})
p.then((res)=>{//res表示的是resolve函数的参数,
console.log("then成功",res);
},(error)=>{
console.log("then失败",error);
})
</script>
<script>
const p= new Promise((resolve,reject)=>{
let a="错了"
reject(a)//reject函数调用相当执行了then方法的第二个参数回调函数
})
p.then((res)=>{
console.log("then成功",res);
},(error)=>{
console.log("then失败",error);//res表示的是reject函数的参数,
})
</script>

6.then方法的返回值

then方法有一个返回值,返回一个新的promise对象,其状态为一个pending。

<script>
const p =new Promise((res,rej)=>{
res(123)
})
const t=p.then(res=>{
return res
},error=>{
return error
})
const a=t.then(res=>{
console.log("1",res);
return res+12
},error=>{
console.log('2',error);
})
a.then(res=>{
console.log("ha",res);
},error=>{
console.log("ww",error)
})
</script>

我们这里可以看到,then方法返回一个新的promise对象,这个新对象的状态为pending。

我们可以在then的回调函数使用return就可以将其状态改成fulfilled,在回调函数内代码出错,状态将会变成rejected。

	<script>
const p =new Promise((res,rej)=>{
res(123)
})
const t=p.then(res=>{
console.log(a);
},error=>{
})
t.then(res=>{
console.log("1",res);
},error=>{
console.log('2',error);
})
</script>

7.promise的catch方法

catch的执行条件:

  • promise的catch方法会在状态为rejected的时候执行
  • promise内部代码有问题的时候执行
  • promise向外抛出错误的时候执行
	<script>
const p=new Promise((res,rej)=>{
rej("500:服务器出错!")
})
p.catch(err=>{
console.log(err);
})
const p2=new Promise((res,rej)=>{
console.log(a);
})
p2.catch(err=>{
console.log("chu",err);
})
</script>

所以一般我们都不使用then方法的第二个函数来捕获错误,而是使用catch来不会promise的rejected状态。

这个可以各管各的,代码更加清晰。

8,解决回调地狱

<script>
const p=new Promise((res,rej)={
$.ajax({
type: "GET",
url: "test.json",
dataType: "json",
success: function (data) {
let { id } = data
res(id)
},
error:function(error){
rej(error)
}
})})
const a= p.then(res=>{
$.ajax({
type: "GET",
url: "test.json",
dataType: "json",
data: { id: res },
success: function (data) {
let { useName } = data
return useName
},
error: function (error) {
throw new error("出错了")
}
})
})
a.then(res=>{
$.ajax({
type: "GET",
url: "test.json",
dataType: "json",
data: { useName: res },
success: function (data) {
let { msg } = data
console.log("已经获取用户信息");
},
error: function (error) {
throw new error("出错了")
}
})
})
</script>

es6高级~promise的更多相关文章

  1. ES6的promise对象研究

    ES6的promise对象研究 什么叫promise? Promise对象可以理解为一次执行的异步操作,使用promise对象之后可以使用一种链式调用的方式来组织代码:让代码更加的直观. 那我们为什么 ...

  2. ES6的Promise

    推荐一下我觉得不错关于Promise的好文章,通俗易懂 说起ES6的Promise就要提及一下JQ的$.when()方法,两者基本相同 面试的时候经常会问Promise,如果同学们能在回答Promis ...

  3. ES6语法 promise用法

    ES6语法 promise用法 function doSomething(){ return new Promise((resolve,reject)=>{ resolve('jjjj');// ...

  4. 浅谈ES6原生Promise

    浅谈ES6原生Promise 转载 作者:samchowgo 链接:https://segmentfault.com/a/1190000006708151 ES6标准出炉之前,一个幽灵,回调的幽灵,游 ...

  5. ES6之Promise用法详解

    一 前言 本文主要对ES6的Promise进行一些入门级的介绍.要想学习一个知识点,肯定是从三个方面出发,what.why.how.下面就跟着我一步步学习吧~ 二 什么是Promise 首先是what ...

  6. ES6中promise总结

    一.什么是ES6的Promise 讲太多也没有.直接在打印出来就好,console.dir(Promise) Promise 是一个构造函数,自身有all, reject, resolve 这几个眼熟 ...

  7. ES6新增"Promise"可避免回调地狱

    Promise是一个构造函数,自己身上有all.reject.resolve这几个眼熟的方法,原型上有then.catch等同样很眼熟的方法. 那就new一个 var p = new Promise( ...

  8. 关于ES6的Promise的使用深入理解

    ES6的promise对象研究 什么叫promise? Promise对象可以理解为一次执行的异步操作,使用promise对象之后可以使用一种链式调用的方式来组织代码:让代码更加的直观. 那我们为什么 ...

  9. 解读Es6之 promise

            单线程:  在同一时间只能有同一任务进行.JavaScript就是一门单线程语言                 当有多个任务需要进行时,则需要进行排队,前一个执行完毕才能执行下一个; ...

  10. 【前端开发】】ES6属性promise封装js动画

    如下是我写的demo源码: 可以直接复制用浏览器打开看到效果哦: <!DOCTYPE html> <html> <head> <meta charset=&q ...

随机推荐

  1. Flutter(二):编写第一个Flutter App

    Create New Flutter Project 在Android Studio添加上Flutter插件以后,通过File -> New -> New Flutter Project创 ...

  2. 鸿蒙HarmonyOS实战-Web组件(基本使用和属性)

    前言 Web是一种基于互联网的技术和资源的网络服务系统.它是指由许多互连的计算机组成的全球性计算机网络,使用户能够通过浏览器访问和交互式使用各种信息和资源,如网页.文档.图片.视频.音频等.通过Web ...

  3. 莫烦tensorflow学习记录 (2)激励函数Activation Function

    https://mofanpy.com/tutorials/machine-learning/tensorflow/intro-activation-function/ 这里的 AF 就是指的激励函数 ...

  4. 【技巧】JS代码这么写,前端小姐姐都会爱上你

    前言 缘由 JS代码小技巧,教你如何守株待妹 你想听的故事: 顶着『前端小王子』的称号,却无法施展自己的才能. 想当年本狗赤手空拳打入前端阵地,就是想通过技术的制高点来带动前端妹子.奈何时不待我,前端 ...

  5. 使用 eBPF 在云中实现网络可观测性

    可观测性是一种了解和解释应用当前状态的能力,也是一种知道何时出现问题的方法.随着在 Kubernetes 和 OpenShift 上以微服务形式进行云部署的应用程序越来越多,可观察性受到了广泛关注.许 ...

  6. 《Android开发卷——自定义日期选择器(二)》

    (小米手机) (中兴手机) 在上一篇中,我介绍了一般公司都会自定义时间日期选择器,并结合自己所做的项目给大家参考. 工作实录之<Android开发卷--自定义日期选择器(一)>链接:htt ...

  7. Python3.7+Robot Framework+RIDE1.7.4.1安装使用教程

    一.解惑:Robot Framewprk今天我们聊一聊,Robot Framework被众多测试工程师误会多年的秘密.今天我们一起来揭秘一下,最近经常在各大群里听到许多同行,在拿Robot Frame ...

  8. JS 过滤掉两个数组中对象id值相等的项

    const arr1 = [{ id: 1, name: '老二' }]; const arr2 = [{ id: 1, name: '网' }, { id: 2, name: '二位' },{ id ...

  9. 『手撕Vue-CLI』完善提示信息

    前言 经过『手撕Vue-CLI』自动安装依赖,已经实现了自动安装依赖的功能. 然而,虽然项目已复制并安装依赖,但其提示信息并不够友好,于是我试着去运行了一下vue create,发现其提示信息是这样的 ...

  10. CodeForces 1935A

    题目链接:Entertainment in MAC 思路 当当前操作次数n为偶数时,若原字符串大于反转字符串则可以将原字符串反转n - 2次,则得到的还是原字符串,此时反转一次,并将其再次反转的字符串 ...