<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>微任务 on 日日是好日</title><link>https://jjjjjjy.github.io/tags/%E5%BE%AE%E4%BB%BB%E5%8A%A1/</link><description>Recent content in 微任务 on 日日是好日</description><generator>Hugo -- gohugo.io</generator><language>zh-cn</language><lastBuildDate>Fri, 13 Mar 2026 14:47:52 +0800</lastBuildDate><atom:link href="https://jjjjjjy.github.io/tags/%E5%BE%AE%E4%BB%BB%E5%8A%A1/index.xml" rel="self" type="application/rss+xml"/><item><title>Promise</title><link>https://jjjjjjy.github.io/posts/javascript/promise/</link><pubDate>Fri, 13 Mar 2026 14:47:52 +0800</pubDate><guid>https://jjjjjjy.github.io/posts/javascript/promise/</guid><description>&lt;h4 id="promise-定义"&gt;Promise 定义
&lt;/h4&gt;&lt;ol&gt;
&lt;li&gt;Promise 是 JS 提供的&lt;strong&gt;异步&lt;/strong&gt;解决方案。&lt;/li&gt;
&lt;li&gt;内部存在三种状态：pending fulfilled rejected。状态一旦改变不可逆。&lt;/li&gt;
&lt;li&gt;Promise 内部维护两个回调队列：onFulfilledCallbacks和onRejectedCallbacks。then 会把回调存入队列。当 resolve 或 reject 时，会执行对应回调。&lt;/li&gt;
&lt;li&gt;then 返回新的 Promise，因此可以实现链式调用。&lt;/li&gt;
&lt;/ol&gt;
&lt;h4 id="promise-状态"&gt;Promise 状态
&lt;/h4&gt;&lt;p&gt;pending 等待
fulfilled 成功
rejected 失败&lt;/p&gt;
&lt;p&gt;状态变化
pending → fulfilled
pending → rejected&lt;/p&gt;
&lt;p&gt;状态一旦改变就不能再变。【原因:避免竞态条件】&lt;/p&gt;
&lt;h4 id="promise-特点"&gt;Promise 特点
&lt;/h4&gt;&lt;p&gt;Promise 最大的特点是 then会返回新的Promise。也就是Promise可以进行链式调用，因此可以解决回调地狱&lt;/p&gt;
&lt;h4 id="promise-本质"&gt;Promise 本质
&lt;/h4&gt;&lt;p&gt;Promise的本质是 状态 + 回调队列&lt;/p&gt;</description></item></channel></rss>