Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimana untuk Memperkenalkan Kelewatan dalam Puppeteer: Apakah Penyelesaian Terbaik?

Bagaimana untuk Memperkenalkan Kelewatan dalam Puppeteer: Apakah Penyelesaian Terbaik?

Patricia Arquette
Patricia Arquetteasal
2024-11-13 14:59:02600semak imbas

How to Introduce Delays in Puppeteer: What are the Best Solutions?

Menjeda Pelaksanaan dalam Puppeteer: Masa Menunggu Sebelum Meneruskan

Apabila bekerja dengan Puppeteer, mungkin perlu memperkenalkan kelewatan sebelum melaksanakan baris berikutnya kod. Walau bagaimanapun, percubaan untuk menggunakan fungsi setTimeout dalam fungsi penilaian sering menemui kegagalan.

Penyelesaian 1: Menggunakan Fungsi Janji

Penyelesaian yang mudah dan berkesan ialah untuk menggunakan fungsi janji, seperti yang ditunjukkan di bawah:

function delay(time) {
   return new Promise(function(resolve) { 
       setTimeout(resolve, time)
   });
}

Untuk membuat kelewatan, cuma panggil fungsi dengan hujah masa yang menyatakan tempoh yang dikehendaki.

console.log('before waiting');
await delay(4000);
console.log('after waiting');

Penyelesaian 2: Menggunakan Puppeteer's waitForTimeout

Puppeteer menyediakan fungsi terbina dalam dipanggil waitForTimeout yang boleh digunakan untuk tujuan ini:

await page.waitForTimeout(4000)

Penyelesaian 3: Menggunakan halaman.evaluate (Diselesaikan Selepas Masa)

Walaupun tidak semudah penyelesaian sebelumnya, adalah mungkin untuk menggunakan page.evaluate untuk mengendalikan tugas ini. Dengan menyelesaikan janji selepas masa yang ditetapkan, kelewatan boleh diperkenalkan:

await page.evaluate(async() => {
    await new Promise(function(resolve) { 
           setTimeout(resolve, 1000)
    });
});

Kesimpulan

Kaedah ini menawarkan pelbagai pendekatan untuk memperkenalkan kelewatan dalam Puppeteer, bergantung pada keperluan dan pilihan khusus pembangun.

Atas ialah kandungan terperinci Bagaimana untuk Memperkenalkan Kelewatan dalam Puppeteer: Apakah Penyelesaian Terbaik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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