Promise之什么是promise?(01)

什么是promise

1.promise是一门新技术(ES6规范)

2.promise是js进行异步编程时的新方案

为什么是新方案?

旧方案;都是回调函数

3.从语法上说 promise是一个构造函数

4.从功能上说promise对象用来封装一个异步编程并可以获取成活或者失败的结果值

异步编程

包括但不限于以下几种

1.fs (nodejs下面的一个模块,可以对磁盘下面的文件进行读取操作) 文件操作

复制代码
require('./index.html',(err,data)=>{}) 回调函数

2.数据库操作 (对mysql等数据库进行操作也是异步操作)

3.ajax

复制代码
$.get('/xxx/xxxApi',params,(data)=>{})
//'/xxx/xxxApi'是请求路径
//params 是请求参数 传参
//(data)=>{} 是回调函数

4.setTimeout

复制代码
setTimeout(()=>{},2000) 同样是回调函数

为什么要使用promise

1.可以链式调用,解决回调地狱的问题

什么是回调地狱?回调函数里面又套回调函数

复制代码
p1(opt,(params1)=>{
	p2(opt,(params2)=>{
		p3(opt,(params3)=>{
			p4(opt,(params4)=>{
				......
			})
		})
	})
})
这样还要每一个单独处理错误操作的代码,导致代码重复
------------------------------------------
//使用promise改造之后
// 用 Promise 链式调用,替代嵌套回调
p1(opt) // 第 1 步:执行 p1
  .then((params1) => { // params1 是 p1 resolve 的结果
    return p2(opt, params1); // 执行 p2,返回它的 Promise
  })
  .then((params2) => { // params2 是 p2 resolve 的结果
    return p3(opt, params2); // 执行 p3,返回它的 Promise
  })
  .then((params3) => { // params3 是 p3 resolve 的结果
    return p4(opt, params3); // 执行 p4,返回它的 Promise
  })
  .then((params4) => { // params4 是 p4 resolve 的结果
    console.log('最终结果:', params4); // 所有步骤完成
  })
  .catch((err) => { // 任何一步出错,都会跳到这里
    console.error('出错了:', err);
  });

2.更为灵活的调用回调函数

之前:要在启动异步函数之前调用回调函数

现在:先启动异步函数=>返回promise后=>在给promise绑定回调函数(也可以在异步任务结束后指定多个回调函数)

相关推荐
阿猫的故乡40 分钟前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
小和尚敲木头1 小时前
vue3 vite动态拼接图片路径
javascript
我叫黑大帅2 小时前
前端如何竖屏固定视口背景
前端·javascript·面试
不会敲代码12 小时前
我花了三天时间,终于把 Cookie、XSS、CSRF 和浏览器存储给整明白了
javascript·面试
贩卖黄昏的熊2 小时前
flex 布局快速梳理
开发语言·javascript·css3·html5
swipe2 小时前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试
kyriewen3 小时前
手写 call、apply、bind:从原理到实现,附 3 个最容易忽略的边界情况
前端·javascript·面试
胡萝卜术3 小时前
从内存视角重新认识 JavaScript 数据类型:一份深度学习笔记
前端·javascript·面试
LiuJun2Son3 小时前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js
烬羽3 小时前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构