首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

滴滴前端高频面试题

(1)Promise的实例有三个状态:Pending(进行中)Resolved(已完成)Rejected(已拒绝)当把一件事情交给promise时,它的状态就是Pending,任务完成了状态就变成了Resolved...(2)Promise的实例有两个过程:pending -> fulfilled : Resolved(已完成)pending -> rejected:Rejected(已拒绝)注意:一旦从进行状态变成为其他状态就永远不能更改状态了...总结: Promise 对象是异步编程的一种解决方案,最早由社区提出。Promise 是一个构造函数,接收一个函数作为参数,返回一个 Promise 实例。...不过测试前还得加一段代码:// promise.js// 这里是上面写的 Promise 全部代码Promise.defer = Promise.deferred = function () {...如果接收方应用程序读数据的速度能够与数据到达的速度一样快,接收方将在每一确认中发送一个正的窗口通告。如果发送方操作的速度快于接收方,接收到的数据最终将充满接收方的缓冲区,导致接收方通告一个零窗口 。

1.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    关于 JavaScript 错误处理的最完整指南(下半部)

    上已经收录,文章的已分类,也整理了很多我的文档,和教程资料。 大家都说简历没项目写,我就帮大家找了一个项目,还附赠【搭建教程】。...result = string.toUpperCase(); return Promise.resolve(result); } 因为使用了 Promise ,所以可以使用 then 来接收返回的内容...; 使用 Promise.any 来处理错误 Promise.any() (Firefox > 79, Chrome > 85) 接收一个 Promise 可迭代对象,只要其中的一个 promise...; 我们传递给Promise.allSettled一个由两个Promise组成的数组:一个已解决,另一个被拒绝。 这种情况 catch 不会被执行, finally 永远会执行。...考虑以下代码: const { readFile } = require("fs"); function readDataset(path) { readFile(path, { encoding

    2.3K20

    JavaScript 错误处理大全【建议收藏】

    在代码中主要用 Error 和 TypeError 这两种最常见的类型来创建自己的错误对象。...它接收错误对象,可以在这里对其进行检查(并远程发送到生产环境中的日志服务器)。 另外无论函数的执行结果如何,不管是成功还是失败,finally 中的所有代码都会被执行。...即使数组中的一个 Promise 拒绝,Promise.all 也会返回失败,而 Promise.any 总是提供第一个已解决的Promise(如果存在于数组中),无论发生了什么拒绝。...这个静态方法没有什么要处理的,因为**即使一个或多个输入 Promise 被拒绝,结果也始终是一个已解决的Promise **。...; 我们将由两个 Promise 组成的数组传递给 Promise.allSettled:一个已解决,另一个被拒绝。 在这种情况下,catch 将永远不会被执行。finally 会运行。

    6.3K50

    这 10 个事例,有助于你理解 ES 中的 Promise

    上已经收录,文章的已分类,也整理了很多我的文档,和教程资料。** 最近开源了一个 Vue 组件,还不够完善,欢迎大家来一起完善它,也希望大家能给个 star 支持一下,谢谢各位了。...) // [TypeError: Chaining cycle detected for promise #Promise>] // Uncaught SyntaxError: Identifier...的参数应为函数,而传递非函数将导致值的结果被忽略,例如.then(2)或.then(Promise.resolve(3)。...当然,如果要重写,下面的代码可以起作用: Promise.resolve() .then(function success1 (res) { throw new Error('success1...---- 代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug。

    41620

    带你写出符合PromiseA+规范Promise的源码

    都有 then 方法,then 接收两个参数,分别是 promise 成功的回调 onFulfilled, * 和 promise 失败的回调 onRejected * 6....首先,在promise实现的代码中,增加以下代码: Promise.defer = Promise.deferred = function () { let dfd = {}; dfd.promise...resolvePromise(promise2, x, resolve, reject) 2.3.1 如果 promise2 和 x 相等,那么 reject promise with a TypeError...rejectPromise 的 入参是 r, reject promise with r. 2.3.3.3.3 如果 resolvePromise 和 rejectPromise 都调用了,那么第一个调用优先...如果传的参数数组是空,则返回的 promise 将永远等待。 如果迭代包含一个或多个非承诺值和/或已解决/拒绝的承诺,则 Promise.race 将解析为迭代中找到的第一个值。

    87220
    领券