Rumah hujung hadapan web tutorial js Pemahaman mendalam tentang teknik js promise chain_javascript

Pemahaman mendalam tentang teknik js promise chain_javascript

May 16, 2016 pm 03:02 PM
js promise

Standard baharu menambah Promise asli.

Di sini kita hanya membincangkan penggunaan rantai, dan memikirkan butirannya.

1 Semakan then() dan catch()

Fungsi panggil balik boleh diletakkan dalam parameter then() dan catch() untuk menerima hasil akhir Promise.

then() boleh menerima parameter, maka panggil balik ini hanya akan dipanggil apabila Promise resolve().

then() juga boleh menerima parameter kedua, kemudian panggil balik kedua digunakan untuk mengendalikan situasi Promise reject().

catch() mengendalikan situasi Promise reject() secara khusus.

Dalam erti kata lain, then() boleh digunakan kedua-dua cara dan catch() hanya boleh mengendalikan situasi reject(). Walau bagaimanapun, adalah disyorkan untuk menggunakan then() untuk mengendalikan resolve() dan catch() untuk mengendalikan reject().

Kedua, walaubagaimanapun, apa yang saya nak bincangkan bukanlah perkara di atas sekadar untuk mengkaji penggunaan asas. Di sini kita mula bercakap tentang nilai pulangan then() dan catch() dan butiran penggunaan rantai.

Kemudian dokumentasi rasmi mengatakan bahawa kedua-dua then() dan catch() mengembalikan Janji, yang sangat menarik. (Saya baru kepada js, ​​dan saya tidak pernah didedahkan dengan janji di alam liar sebelum ini).

Pertama sekali, Janji yang baru dikembalikan ini bukanlah Janji yang asal

Kedua, perubahan dalam status Janji yang baru dikembalikan ini (sama ada azam() atau tolak().) berkaitan dengan status Janji sebelumnya dan cara kemudian() digunakan.

Terangkan dahulu situasi kemudian(): (serupa dengan tangkapan)

var p1 = Promise.resolve("Success");
var p2 = p1.then(task1);
var p3 = p2.then(task2);
Salin selepas log masuk

Nota: Tugas1 dan tugas2 di atas adalah kedua-duanya panggilan balik.

Di sini, p1 ialah Janji yang dicipta dan diselesaikan() secara langsung

p2 ialah Janji yang diperolehi dengan menggunakan then(), dan p3 juga Janji yang diperolehi dengan menggunakan then().

Jadi bagaimana status p2 berubah?

Saya akan menggunakan gambar berikut untuk menerangkan konsep ini:

Antaranya,

1. Oktagon mewakili objek Janji.

2. Bulatan mewakili keadaan dalaman Janji, dan anak panah hitam mewakili perubahan keadaan.

3. Anak panah kanan mewakili memanggil fungsi kemudian.

4. Dengan kata lain, selagi fungsi itu dipanggil, objek Promise baharu akan dihasilkan.

5. Apabila memanggil fungsi kemudian, saya tidak tahu apakah status objek Janji sebelumnya, adakah ia belum selesai atau diselesaikan? Ini tidak boleh diandaikan dan tidak boleh dilihat dari dunia luar.

6. Panggilan fungsi kemudian tidak akan menyekat, iaitu, p2 dan p3 dijana hampir serta-merta, walaupun p1 masih perlahan-lahan memindahkan keadaannya sendiri.

Kami tahu bahawa status p1 telah diselesaikan (lihat kod di atas). Namun, belum dijelaskan di sini bagaimana status p2 dan p3 berubah Adakah ia diselesaikan atau ditolak? Lihat imej baharu di bawah.

Anda boleh melihat lebih banyak bentuk berlian.

Berlian mewakili fungsi panggil balik yang dihantar semasa membuat panggilan. Berlian ke atas mewakili pemprosesan masuk [untuk objek Janji sebelumnya yang telah diselesaikan] dan berlian ke bawah mewakili pemprosesan masuk [untuk objek Janji sebelumnya yang ditolak].

Nota: Dalam contoh ini, tidak ada pemprosesan penolakan, maksudnya, belah ketupat ke bawah tidak boleh dilukis dalam gambar di atas adalah khusus kepada kami. Bagaimana untuk menggunakan kemudian atau menangkap. Lihat sekali lagi pada kod sampel:

<span>var</span> p1 = Promise.resolve("Success"<span>);</span><span>var</span> p2 =<span> p1.then(task1);//产生了向上的菱形</span><span>var</span> p3 = p2.then(task2);//产生了向上的菱形
Salin selepas log masuk

Seperti yang anda lihat, kami tidak memberikan parameter kedua pada masa itu, yang bermaksud kami tidak mengendalikan situasi penolakan.

Selain itu, kalau nak handle reject, boleh pakai lepas tu, atau boleh guna Catch digunakan khas untuk handle reject.

1. Jika keadaan akhir p1 (selesai atau tolak) diproses dengan betul (apabila memanggil kemudian, panggilan balik yang sepadan dihantar, iaitu, terdapat berlian yang sepadan), maka keadaan p2 akan berubah untuk menyelesaikan .

2. Jika keadaan akhir p1 (selesai atau tolak) tidak diproses dengan betul (apabila membuat panggilan, panggilan balik yang sepadan hilang, iaitu, tiada berlian yang sepadan), maka keadaan p1 akan dihalakan ke p2 (menerima status p1).

3. Sampaikan seperti ini.

4. Artikel ini tidak menerangkan cara mendapatkan data akhir Janji sebelumnya dalam panggilan balik, iaitu cara memindahkan data Terdapat banyak tutorial mengenai perkara ini.

Tiga, beberapa contoh diberikan di bawah untuk meringkaskan artikel ini.

Status P1 dalam gambar diberi, azam atau tolak semuanya diberikan sendiri. Matlamatnya adalah untuk menyimpulkan keadaan akhir P2 dan P3.

Di atas ialah empat contoh bebas tanpa kaitan antara mereka.

X bermaksud P3 tidak menggunakan fungsi then atau catch, jadi tiada cara untuk menangani penyelesaian atau penolakan.

Akhir sekali, jika terdapat sebarang kesilapan, sila betulkan tepat pada masanya, terima kasih! ~! ! @~~~

Pemahaman mendalam tentang rantai janji js di atas adalah semua kandungan yang dikongsi oleh editor saya harap ia dapat memberi rujukan kepada anda, dan saya harap anda akan menyokong Script Home.

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara menggunakan Peta JS dan Baidu untuk melaksanakan fungsi pan peta Cara menggunakan Peta JS dan Baidu untuk melaksanakan fungsi pan peta Nov 21, 2023 am 10:00 AM

Cara menggunakan JS dan Baidu Map untuk melaksanakan fungsi pan peta Baidu Map ialah platform perkhidmatan peta yang digunakan secara meluas, yang sering digunakan untuk memaparkan maklumat geografi, kedudukan dan fungsi lain dalam pembangunan web. Artikel ini akan memperkenalkan cara menggunakan API Peta JS dan Baidu untuk melaksanakan fungsi pan peta dan memberikan contoh kod khusus. 1. Persediaan Sebelum menggunakan API Peta Baidu, anda perlu memohon akaun pembangun pada Platform Terbuka Peta Baidu (http://lbsyun.baidu.com/) dan mencipta aplikasi. Penciptaan selesai

Disyorkan: Projek pengesanan dan pengecaman muka sumber terbuka JS yang sangat baik Disyorkan: Projek pengesanan dan pengecaman muka sumber terbuka JS yang sangat baik Apr 03, 2024 am 11:55 AM

Teknologi pengesanan dan pengecaman muka adalah teknologi yang agak matang dan digunakan secara meluas. Pada masa ini, bahasa aplikasi Internet yang paling banyak digunakan ialah JS Melaksanakan pengesanan muka dan pengecaman pada bahagian hadapan Web mempunyai kelebihan dan kekurangan berbanding dengan pengecaman muka bahagian belakang. Kelebihan termasuk mengurangkan interaksi rangkaian dan pengecaman masa nyata, yang sangat memendekkan masa menunggu pengguna dan meningkatkan pengalaman pengguna termasuk: terhad oleh saiz model, ketepatannya juga terhad. Bagaimana untuk menggunakan js untuk melaksanakan pengesanan muka di web? Untuk melaksanakan pengecaman muka di Web, anda perlu biasa dengan bahasa dan teknologi pengaturcaraan yang berkaitan, seperti JavaScript, HTML, CSS, WebRTC, dll. Pada masa yang sama, anda juga perlu menguasai visi komputer yang berkaitan dan teknologi kecerdasan buatan. Perlu diingat bahawa kerana reka bentuk bahagian Web

Cara membuat carta candlestick saham menggunakan PHP dan JS Cara membuat carta candlestick saham menggunakan PHP dan JS Dec 17, 2023 am 08:08 AM

Cara menggunakan PHP dan JS untuk mencipta carta lilin saham Carta lilin saham ialah grafik analisis teknikal biasa dalam pasaran saham Ia membantu pelabur memahami saham dengan lebih intuitif dengan melukis data seperti harga pembukaan, harga penutup, harga tertinggi. dan harga terendah turun naik harga saham. Artikel ini akan mengajar anda cara membuat carta lilin saham menggunakan PHP dan JS, dengan contoh kod khusus. 1. Persediaan Sebelum memulakan, kita perlu menyediakan persekitaran berikut: 1. Pelayan yang menjalankan PHP 2. Pelayar yang menyokong HTML5 dan Kanvas 3

Alat penting untuk analisis saham: Ketahui langkah-langkah untuk melukis carta lilin dengan PHP dan JS Alat penting untuk analisis saham: Ketahui langkah-langkah untuk melukis carta lilin dengan PHP dan JS Dec 17, 2023 pm 06:55 PM

Alat penting untuk analisis saham: Pelajari langkah-langkah untuk melukis carta lilin dalam PHP dan JS, contoh kod khusus diperlukan Dengan perkembangan pesat Internet dan teknologi, perdagangan saham telah menjadi salah satu cara penting bagi banyak pelabur. Analisis saham adalah bahagian penting dalam membuat keputusan pelabur, dan carta lilin digunakan secara meluas dalam analisis teknikal. Mempelajari cara melukis carta lilin menggunakan PHP dan JS akan memberikan pelabur maklumat yang lebih intuitif untuk membantu mereka membuat keputusan yang lebih baik. Carta candlestick ialah carta teknikal yang memaparkan harga saham dalam bentuk candlestick. Ia menunjukkan harga saham

Menepati janji anda: Kebaikan dan keburukan menunaikan janji anda Menepati janji anda: Kebaikan dan keburukan menunaikan janji anda Feb 18, 2024 pm 08:06 PM

Dalam kehidupan seharian, kita sering menghadapi masalah antara janji dan menunaikan. Sama ada dalam hubungan peribadi atau transaksi perniagaan, menunaikan janji adalah kunci untuk membina kepercayaan. Walau bagaimanapun, kebaikan dan keburukan komitmen sering menjadi kontroversi. Artikel ini akan meneroka kebaikan dan keburukan komitmen dan memberi beberapa nasihat tentang cara untuk mengekalkan kata-kata anda. Faedah yang dijanjikan adalah jelas. Pertama, komitmen membina kepercayaan. Apabila seseorang menepati kata-katanya, dia membuat orang lain percaya bahawa dia seorang yang boleh dipercayai. Kepercayaan adalah ikatan yang terjalin antara orang, yang boleh menjadikan orang lebih banyak

Cara menggunakan JS dan Baidu Map untuk melaksanakan fungsi pemprosesan acara klik peta Cara menggunakan JS dan Baidu Map untuk melaksanakan fungsi pemprosesan acara klik peta Nov 21, 2023 am 11:11 AM

Gambaran keseluruhan tentang cara menggunakan Peta JS dan Baidu untuk melaksanakan fungsi pemprosesan acara klik peta: Dalam pembangunan web, selalunya perlu menggunakan fungsi peta untuk memaparkan lokasi geografi dan maklumat geografi. Pemprosesan acara klik pada peta ialah bahagian yang biasa digunakan dan penting dalam fungsi peta. Artikel ini akan memperkenalkan cara menggunakan API Peta JS dan Baidu untuk melaksanakan fungsi pemprosesan acara klik pada peta dan memberikan contoh kod khusus. Langkah: Import fail API Peta Baidu Pertama, import fail API Peta Baidu dalam fail HTML Ini boleh dicapai melalui kod berikut.

Cara menggunakan Peta JS dan Baidu untuk melaksanakan fungsi peta haba peta Cara menggunakan Peta JS dan Baidu untuk melaksanakan fungsi peta haba peta Nov 21, 2023 am 09:33 AM

Cara menggunakan Peta JS dan Baidu untuk melaksanakan fungsi peta haba peta Pengenalan: Dengan perkembangan pesat Internet dan peranti mudah alih, peta telah menjadi senario aplikasi biasa. Sebagai kaedah paparan visual, peta haba boleh membantu kami memahami pengedaran data dengan lebih intuitif. Artikel ini akan memperkenalkan cara menggunakan API Peta JS dan Baidu untuk melaksanakan fungsi peta haba peta dan memberikan contoh kod khusus. Kerja penyediaan: Sebelum memulakan, anda perlu menyediakan item berikut: akaun pembangun Baidu, buat aplikasi dan dapatkan AP yang sepadan

Petua Pembangunan PHP dan JS: Kuasai Kaedah Melukis Carta Lilin Stok Petua Pembangunan PHP dan JS: Kuasai Kaedah Melukis Carta Lilin Stok Dec 18, 2023 pm 03:39 PM

Dengan perkembangan pesat kewangan Internet, pelaburan saham telah menjadi pilihan semakin ramai orang. Dalam perdagangan saham, carta lilin adalah kaedah analisis teknikal yang biasa digunakan Ia boleh menunjukkan trend perubahan harga saham dan membantu pelabur membuat keputusan yang lebih tepat. Artikel ini akan memperkenalkan kemahiran pembangunan PHP dan JS, membawa pembaca memahami cara melukis carta lilin saham dan menyediakan contoh kod khusus. 1. Memahami Carta Lilin Saham Sebelum memperkenalkan cara melukis carta lilin saham, kita perlu memahami dahulu apa itu carta lilin. Carta candlestick telah dibangunkan oleh orang Jepun

See all articles