<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
程式碼如下:
// Make a request for user.json fetch('/article/promise-chaining/user.json') // Load it as json .then(response => response.json()) // Make a request to GitHub .then(user => fetch(`https://api.github.com/users/${user.name}`)) // Load the response as json .then(response => response.json()) // Show the avatar image (githubUser.avatar_url) for 3 seconds (maybe animate it) .then(githubUser => { let img = document.createElement('img'); img.src = githubUser.avatar_url; img.className = "promise-avatar-example"; document.body.append(img); setTimeout(() => img.remove(), 3000); // (*) });
這裡的語意比較清楚,每一個 then 呼叫都返回一個 Promise,後續的 then 呼叫,必須在前一個 then 呼叫返回的 Promise 被 resolve 之後,才能得到執行。
不過上述程式碼有一個缺陷:
看 *
所在行的程式碼:在頭像完成顯示並被移除後,如果我們想新增一些額外的處理邏輯,應該怎麼做? 例如,我們想顯示一個用於編輯該使用者或其他內容的表單。
為了使鏈可延伸,我們需要返回一個在頭像完成顯示時進行 resolve 的 Promise.
程式碼如下:
fetch('/article/promise-chaining/user.json') .then(response => response.json()) .then(user => fetch(`https://api.github.com/users/${user.name}`)) .then(response => response.json()) .then(githubUser => new Promise(function(resolve, reject) { // (*) let img = document.createElement('img'); img.src = githubUser.avatar_url; img.className = "promise-avatar-example"; document.body.append(img); setTimeout(() => { img.remove(); resolve(githubUser); // (**) }, 3000); })) // triggers after 3 seconds .then(githubUser => alert(`Finished showing ${githubUser.name}`));
也就是說,(*) 行中的 .then 處理程式現在返回新的 Promise,該 Promise 僅在 setTimeout (**) 中的 resolve(githubUser) 呼叫後才被解決。 鏈中的下一個 .then 將等待它。
下圖第 5 行新建的 Promise 物件,這個物件在第 13 行會 resolve,這個 resolve 操作,會觸發等待它的第 17 行的 then 方法。
作為一種好的實踐,非同步操作應始終返回一個 Promise. 這使得在它之後的計劃行動成為可能;即使我們現在不打算擴充套件鏈,我們以後也可能需要它。
最後我們對程式碼進行重構。
function loadJson(url) { return fetch(url) .then(response => response.json()); }
以上的函數返回一個 Promise,當 response 的 json 資料可用時,這個 promise 後註冊的 .then
函數就會觸發。
看其消費程式碼:
26 行 then 裡的箭頭函數觸發時,user 就是 25 行 user.json 資料被反序列化之後形成的 JSON 物件。
function loadGithubUser(name) { return loadJson(`https://api.github.com/users/${name}`); }
只是對 loadJson 的一層封裝,讓呼叫者不需要知道 Github user api 具體的 endpoint.
function showAvatar(githubUser) { return new Promise(function(resolve, reject) { let img = document.createElement('img'); img.src = githubUser.avatar_url; img.className = "promise-avatar-example"; document.body.append(img); setTimeout(() => { img.remove(); resolve(githubUser); }, 3000); }); }
返回一個 Promise,在其 executor 裡書寫業務邏輯,並通過 resolve(githubUser) 將 Promise 狀態設定為 fulfilled,方便將來的擴充套件。
最後的完整程式碼:
// Use them: loadJson('/article/promise-chaining/user.json') .then(user => loadGithubUser(user.name)) .then(showAvatar) .then(githubUser => alert(`Finished showing ${githubUser.name}`)); // ...
總結:
如果 .then(或 catch/finally,無關緊要)處理程式返回一個 Promise,則 Promise 鏈的其餘部分會一直等待,直到這個 pending 的 Promise 被 resolve. 當 Promise 內部的 executor 有資料被 resolve 呼叫時,resolve 輸入的資料(或錯誤)會被進一步傳遞到 Promise chain 裡的其他 Promise.then 中去。
到此這篇關於使用 JavaScript Promise 讀取 Github 使用者資料的文章就介紹到這了,更多相關 JavaScript Promise 讀取內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45