※ 認識非同步概念(二)

閱讀時間約 2 分鐘

※ Promise基本介紹

什麼是 Promise?

Promise 是 JavaScript 的一個構造函式,用於創建表示非同步操作的物件實例。使用 new Promise() 時,你會創建一個包含非同步操作的實例,這個實例可以透過其繼承的方法如 then(), catch(), 和 finally() 來管理非同步操作的成功、失敗及其後續處理。

在創建 Promise 時,必須提供一個執行器函數(executor function),這個函數會立即執行並接收兩個參數:resolvereject。這些參數是函數,用於在異步操作成功時調用 resolve,或在操作失敗時調用 reject

Promise 它具備了 callback 的優點,但透過 .then() 來標明流程,而 .then() 之間可以互相鏈結 (chaining),把之前「一層包一層的 callback」,轉換成 .then() 的串接。

以下是Promise的基本形式:

function asyncFunction(value) {
return new Promise(function(resolve, reject) {
if(value) {
resolve(value)//已實現,成功
}else {
reject(reason)//有錯誤,已拒絕,失敗
}
})
}

簡單範例:

//resolve的結果
function delay() {
return new Promise(function(resolve, reject) {
setTimeout(function() {
resolve("Hello")
}, 1000)
})
}
//以下是一個Promise接到resolve的結果就設計成一個子函式(then)後再接到一個值後再印出
delay().then((res) => console.log(res))//印出"Hello"
//reject的結果
function delay() {
return new Promise(function(resolve, reject) {
setTimeout(function() {
reject("Error")
}, 1000)
})
}
delay().catch((res) => console.log(res))//印出"Error"

以下是Promise的流程圖示:

raw-image



    全端網頁開發專業知識分享
    留言0
    查看全部
    發表第一個留言支持創作者!
    認識 JavaScript (十一)
    閱讀時間約 2 分鐘
    認識 JavaScript (十二)
    閱讀時間約 4 分鐘
    認識 JavaScript (十三)
    閱讀時間約 1 分鐘
    認識 JavaScript (十四)
    閱讀時間約 3 分鐘
    認識 JavaScript (十五)
    閱讀時間約 9 分鐘
    ※ 認識非同步概念(一)
    閱讀時間約 3 分鐘
    你可能也想看
    創作者要怎麼好好休息 + 避免工作過量?《黑貓創作報#4》午安,最近累不累? 這篇不是虛假的關心。而是《黑貓創作報》發行以來可能最重要的一篇。 是的,我們這篇講怎麼補充能量,也就是怎麼休息。
    Thumbnail
    avatar
    黑貓老師
    2024-06-29
    認識使命。 (非宗教)透過擁有使命時的感受,以及其感受作為基底的來源,使用自己的生命。 下限有希特勒作為借鏡,上限有帶領AI作為發展前沿,縱使還不熟悉,也早晚會在過程中認識使命。
    avatar
    始力拼達人
    2024-02-07
    快速認識阿拉伯文字母與變形體(非專業教學)本文解惑阿拉伯文為何看起來像一條蟲,並介紹阿語字母與變形體。
    Thumbnail
    avatar
    雪莉思 Sherry
    2023-09-10
    13天日本深度旅行:飛驒高山基本篇 ──帶你一次掌握好吃好玩,認識飛驒高山全貌!大家來日本旅行前可能都只聽過合掌村,卻沒什麼聽過合掌村周遭的城市,但其實在合掌村附近有一個名叫飛驒高山的城市,這個城市既有像鄉村般的古色古香和樸素氛圍,又同時兼具都市般的熱鬧和方便,而且美食和景點夠你逛三天三夜!這次就要帶大家以簡單清楚的方式,體驗高山好吃好玩的景點和美食,並讓大家認識高山這個地方!
    Thumbnail
    avatar
    Kenny的隨手日誌
    2023-08-17
    菲菲心靈:自我認識的深化經常忽略了自己內在深處的聲音 在這快節奏的現代生活中,我們總是被迫奔波於各種工作、學習和家庭事務之間。這種忙碌使我們往往忽略了內在深處的聲音,忘記了自己的真正渴望和內心的需求。每天的壓力讓我們只能應付眼前的困難,卻忘了細細品味生活的真諦。 在城市的喧囂中,我們忘記了自己 在城市的喧囂中,我們很
    Thumbnail
    avatar
    月菲
    2023-07-31
    擴大你對英文句型的認識(下):主詞+be動詞然後可以接什麼?【英語能力起飛】在(上)時我們從「I am _____ .」開始,引導讀者一路來到了句型「主詞+be+介詞片語」,本篇(下)要跟讀者分享常用和好用的例句,同時邀請付費訂閱的讀者透過留言功能挑一個或本文提到的所有例子來造句,老師會幫揪錯。 首先分享一個描述位置的實用句型。請看: 可拿來形容自己住的地方交通有多便利:
    Thumbnail
    avatar
    英語能力起飛
    2022-04-18
    avatar
    英語能力起飛
    2022-04-14
    你真的認識聖索菲亞大教堂嗎?世界級大師帶你導覽經典建築景點!位於伊斯坦堡的聖索菲亞大教堂,是到土耳其旅遊時必去的景點,但除了歷史課本上有學過的拜占庭歷史外,你對這座建築了解嗎? 今天透過世界級建築師羅伯特‧麥卡特以及2018威尼斯建築展「田中央工作群」的策展顧問尤哈尼‧帕拉斯瑪,帶你「紙上VR導覽」聖索菲亞大教堂這座既熟悉又陌生的建築吧!
    Thumbnail
    avatar
    原點出版社
    2021-08-30
    [阿飛的人生相談所]第17集:認識很久卻還不懂我!這該怎麼辦?「阿飛的人生相談所」,故名思義就是聊人生的各種問題,我會在這裡用聲音跟讀者聊聊日常生活的大小事,也會開放讀者留言與來信提問,無論是感情上、工作上或是家庭、人際關係的問題都可以留言或來信問我,然後我會從中挑選適合的問題在音頻聊聊我的看法,當然不想問問題,單純留言給我鼓勵,我也非常開心。
    Thumbnail
    avatar
    阿飛
    2020-12-27
    認識菲律賓股市及法規淺談菲律賓股市及相關法規
    Thumbnail
    avatar
    Rae Kuo 瑞瑞
    2020-11-25
    認識「結構化/半結構化/非結構化」資料結構化資料: 事先定義好每個欄位可以存放什麼資料,這種儲存的資料就是結構化資料。 像是關聯式資料庫中的資料,需要先把table欄位定義好,之後才能儲存資料。 半結構化資料: 無需事先定義好資料欄位,每一筆資料能夠根據需求儲存不同的欄位,因此很有彈性,如JSON, XML等等。 非結構化資料: 未整理
    avatar
    Vic Lin
    2020-10-09