Promise ialah aspek asas pengaturcaraan tak segerak dalam JavaScript. Apabila ia berkaitan dengan async/menunggu, adalah penting untuk menyahtafsirkan tanggapan bahawa fungsi async sentiasa mengembalikan Promise.
Kata kunci tunggu, diletakkan sebelum panggilan fungsi Promise-returning, menangguhkan pelaksanaan fungsi semasa sehingga Janji sama ada diselesaikan atau ditolak. Walau bagaimanapun, penggantungan ini tidak membatalkan Janji. Hasil Promise masih terkandung dalam objek Promise yang dikembalikan.
Untuk menggambarkan, pertimbangkan kod berikut yang mensimulasikan permintaan tak segerak:
const getJSON = async () => { const request = () => new Promise((resolve, reject) => ( setTimeout(() => resolve({ foo: 'bar' }), 2000) )); const json = await request(); return json; };
Apabila menggunakan getJSON(), ia kembali Janji kerana kenyataan menunggu hanya menangguhkan pelaksanaan sehingga permintaan selesai:
console.log(getJSON()); // returns Promise
Sebaliknya, apabila merantai .then(), hasil Janji akhirnya terdedah:
getJSON().then(json => console.log(json)); // prints { foo: 'bar' }
Mengapa anda tidak boleh memintas pembalut Janji dengan konsol .log(getJSON())? Ini adalah harta asas Janji. Janji mewakili operasi tak segerak, dan keputusannya tidak diketahui sehingga ia diselesaikan atau ditolak. Akses luaran kepada keputusan dilarang dengan sengaja, memastikan Janji kekal sebagai pengantara tunggal keputusan.
Ingat, async/wait menjadikan kerja dengan Promises lebih mudah dengan menggantung pelaksanaan apabila Janji ditemui, tetapi ia tidak keluarkan keperluan untuk membuka Janji untuk mengakses keputusannya.
Atas ialah kandungan terperinci Adakah async/menunggu dalam JavaScript Sentiasa Mengembalikan Janji, dan Mengapa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!