2024年前端最全前端面试官问Promise,怎样回答拿高分_面试官问promise怎么回答,2024年最新腾讯web前端面试题

最后

面试题千万不要死记,一定要自己理解,用自己的方式表达出来,在这里预祝各位成功拿下自己心仪的offer。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

大厂面试题

面试题目录

return sayhello(“third”);
}).then(function () {
console.log(‘end’);
}).catch(function (err) {
console.log(err);
})


这样代码阅读起来就比较方便了,而且也能够拿到异步的数据。


###### 信任问题:


回调函数不能保证什么时候去调用回调,以及使用什么方式去调用回调;而Promise一旦被确认成功或失败,就不能再被更改。Promise成功之后仅调用一次resolve(),不会产生回调多次执行的问题。除非Promise再次调用。所以Promise很好地解决了第三方工具导致的回调多次执行(控制反转)的问题,这个问题也称为信任问题。


###### 6.你自己实现过吗,什么场景?


根据第五点上述回答


###### 7.promise的基本用法


ES6 规定,Promise对象是一个构造函数,用来生成Promise实例。


下面代码创造了一个Promise实例。



const promise = new Promise(function(resolve, reject) {
// … some code

if (/* 异步操作成功 */){
resolve(value);
} else {
reject(error);
}
});


Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve和reject。它们是两个函数,由 JavaScript 引擎提供,不用自己部署。


resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;reject函数的作用是,将Promise对象的状态从“未完成”变为“失败”(即从 pending 变为 rejected),在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。


Promise实例生成以后,可以用then方法分别指定resolved状态和rejected状态的回调函数。


###### 8.实现promise.all



function PromiseAll(promises){
return new Promise((resolve, reject)=>{
if(!Array.isArray(promises)){
throw new TypeError(“promises must be an array”)
}
let result = []
let count = 0
promises.forEach((promise, index) => {
promise.then((res)=>{
result[index] = res
count++
count === promises.length && resolve(result)
}, (err)=>{
reject(err)
})
})
})
}


###### 9.实现 promise.finally


来说一下如何串行执行多个Promise



Promise.prototype.finally = function (cb) {
return this.then(function (value) {
return Promise.resolve(cb()).then(function () {
return value
})
}, function (err) {
return Promise.resolve(cb()).then(function () {
throw err
})
})
}


###### 10.实现 promise.race



Promise.race = function(promiseArr) {
return new Promise((resolve, reject) => {
promiseArr.forEach(p => {
Promise.resolve§.then(val => {
resolve(val)
}, err => {
rejecte(err)
})
})
})
}


###### 11.实现 promise.any



Promise.any = function(promiseArr) {
let index = 0
return new Promise((resolve, reject) => {
if (promiseArr.length === 0) return
promiseArr.forEach((p, i) => {
Promise.resolve§.then(val => {
resolve(val)

        }, err => {
            index++
            if (index === promiseArr.length) {
              reject(new AggregateError('All promises were rejected'))
            }
        })
    })
})

}


###### 12.实现 promise.resolve



Promise.resolve = function(value) {
if(value instanceof Promise){
return value
}
return new Promise(resolve => resolve(value))

最后

由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**

[外链图片转存中…(img-w4nFu5cC-1715528484047)]

[外链图片转存中…(img-CQmBHHKN-1715528484048)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值