0429 手打基础丸

手打基础丸 🧆 => 精选基础知识,经过多道工序精心制作而成,口感鲜嫩多汁。一口咬下,香气四溢,加上传统前端风味,令人回味无穷...... 助力食用者厚积薄发,夯实根基进阶上层。

Promise?

是ES6新增的一个处理异步操作的对象,支持链式调用避免回调地狱。同时新增的async/await是Promise的语法糖。

Promise状态:Pending(待定,初始状态),Fullfiled(操作成功),Rejected(操作失败)

javascript 复制代码
const promise = new Promise((resolve, reject)=>{})
promise.then(result => {
// 使用then进行函数回调
 console.log(result)
}).catch(error => {
// 需要手动处理异常
  console.log(error)
}).finally(()=>{
//无论失败还是成功都会执行的部分
  console.log('操作完成')
})

JS中异步编程方式?

回调函数:将函数作为参数传递给另一个函数,多层嵌套即回调地狱

Promise:链式处理函数回调,避免了回调地狱

async/await:Promise的语法糖,增加了可读性

事件监听:处理用户交互和网络请求等异步事件

定时函数:setTimeout、setInterval,会受事件循环影响

Promise.all和Promise.allsettled区别?

Promise.all

并行执行多个Promise

如果有一个Promise失败则进行立即返回失败的promise,如果都成功则最终返回一个包含所有成功个结果的数组。

javascript 复制代码
const promise1 = Promise.resolve('promise1')
const promise2 = 22
const promise3 = new Promise((resolve, reject) => {
  setTimeout(resolve, 500, 'promise3')
})
Promise.all([promise1, promise2, promise3]).then((values) => {
  console.log(values)// ["promise1", 22,  'promise' ]
})

Promise.allSettled

并行执行多个Promise

每次Promise无论成功还是失败都会返回一个Promise,包含Promise的状态和结果。

javascript 复制代码
const promise4 = new Promise((resolve, reject) => {setTimeout(reject, 500, "rejectPromise4")})
Promise.all([promise1, promise3, promise4]).then((values) => {
values.forEach((value) =>console.log(values))
// {status: "fullfilled", value: "promise1"}
// {status: "fullfiled", value: "foo"}
// {status: "rejected", reason: "rejectPromise4"}
})
相关推荐
小码哥_常13 分钟前
Room 3.0:移动端持久化的“重生”变革
前端
Front思1 小时前
前端的.hbs
前端
_.Switch1 小时前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI1 小时前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
普通网友1 小时前
ES6模块化、Promise、async、await、EventLoop、API接口案例_export function 与 await
前端·ecmascript·es6
難釋懷1 小时前
Vue混入
前端·javascript·vue.js
若梦plus1 小时前
TypeScript进阶
前端·javascript·typescript·ecmascript
直奔標竿1 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
@PHARAOH2 小时前
WHAT - cursor cli 开发范式
前端·ai·ai编程
子兮曰3 小时前
深入 HTML-in-Canvas:当 Canvas 学会了渲染 DOM,前端图形生态要变天了
前端·javascript·canvas