Rumah > hujung hadapan web > tutorial js > JavaScript kaedah .then / .when.

JavaScript kaedah .then / .when.

DDD
Lepaskan: 2024-10-17 06:27:29
asal
750 orang telah melayarinya

JavaScript the .then / .when method.

Hari ini, saya mengikuti tutorial WordPress, dan pengajar sedang menunjukkan cara mencari tapak menggunakan jQuery dan JavaScript, khususnya menggunakan kaedah .then() dan .when(). Semasa saya mengikutinya, saya menyedari bahawa saya tidak begitu biasa dengan kaedah ini seperti yang saya fikirkan.

Jadi, saya melakukan sedikit penyelidikan, mengambil beberapa nota dan menambahkannya pada buku nota Obsidian saya. Sejujurnya, nota itu agak kasar—ia kelihatan seperti sesuatu yang boleh disatukan oleh pelajar darjah lima dengan rentang perhatian tupai (yang, biarlah, kadangkala terasa seperti saya!).

Tetapi saya fikir, mengapa tidak berkongsinya? Jika mereka membantu walaupun seorang, ia berbaloi untuk disiarkan.


Bayangkan ini:

Anda berada di sekolah, dan anda serta rakan anda membuat janji antara satu sama lain. Janji-janji ini seperti berkata, "Saya akan menyiapkan kerja rumah saya, dan kemudian kita boleh bermain permainan."

Tetapi inilah perkaranya: kadangkala memerlukan sedikit masa untuk menyiapkan kerja rumah. Anda mungkin menghabiskannya dengan cepat, atau mungkin anjing anda memakannya, dan anda tidak pernah menghabiskannya (ops!). Janji JavaScript berfungsi dengan cara yang sama. Ia menunggu sesuatu berlaku, dan kemudian ia berkata, “Baiklah, apa seterusnya?”

Sekarang, mari bercakap tentang .then():

Kaedah .then() adalah seperti apa yang anda akan lakukan selepas janji dilakukan. Bayangkan anda berkata kepada rakan anda:

  • “Jika saya menyelesaikan kerja rumah saya, maka kita boleh bermain permainan video!”

Tetapi bagaimana jika anda tidak selesai? Eh-oh, anda boleh menambah pelan sandaran:

  • “Jika saya tidak menyiapkan kerja rumah saya, maka kami tidak akan bermain permainan video.”

Begini cara anda mengatakan ini dalam JavaScript:

promiseToFinishHomework
  .then(() => {
    console.log("Yay! We can play games!"); // If you finished
  })
  .catch(() => {
    console.log("Oh no! No games today!"); // If you didn’t finish
  });
Salin selepas log masuk

Sekarang untuk .when():

Ini adalah seperti apabila anda sedang menunggu sekumpulan rakan anda untuk menyelesaikan kerja rumah mereka supaya anda semua boleh bermain bersama-sama. Anda seperti:

  • “Apabila kita semua selesai, barulah kita boleh bermain bersama-sama!”

Dalam kehidupan sebenar, itu dipanggil bekerja bersama. Dalam JavaScript, anda menggunakan sesuatu yang dipanggil Promise.all() (yang sama seperti berkata "Mari kita tunggu semua orang bersedia!"):

Promise.all([friend1, friend2]).then(() => {
  console.log("We’re all done! Time to play!");
});
Salin selepas log masuk

Ringkasan (Super Simple):

  • .then() Seperti berkata "Apabila perkara ini selesai, maka kami akan melakukan sesuatu yang menyeronokkan."
  • .apabila() (atau Janji.semua()) seperti berkata "Apabila semua orang selesai kerja mereka, maka kita semua akan bermain bersama-sama."

Jadi, JavaScript hanya memastikan ia mengetahui apa yang berlaku seterusnya apabila janji ditepati—atau dimungkiri! ?


Jadi Bagaimana Ia Tahu?

Janji tidak menyemak kerja rumah dengan sendirinya. Anda beritahu! Apabila anda membuat janji, anda memutuskan sama ada ia diselesaikan atau ditolak berdasarkan sama ada tugas (seperti menyiapkan kerja rumah) selesai atau tidak. .then() berjalan apabila janji diselesaikan dan .catch() berjalan apabila ia ditolak.

Contoh Dengan Tindakan Kehidupan Sebenar:

Berikut ialah contoh penuh untuk melihatnya dalam tindakan:

let promiseToFinishHomework = new Promise((resolve, reject) => {
  let finishedHomework = true; // Change this to false to see the rejection

  if (finishedHomework) {
    resolve(); // Homework is done!
  } else {
    reject(); // Homework is not done!
  }
});

promiseToFinishHomework
  .then(() => {
    console.log("Yay! We can play games!"); // If the promise resolves (homework done)
  })
  .catch(() => {
    console.log("Oh no! No games today!"); // If the promise rejects (homework not done)
  });

Salin selepas log masuk

Atas ialah kandungan terperinci JavaScript kaedah .then / .when.. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan