Bagaimana untuk Menjana PDF daripada Aplikasi Satu Halaman dengan Puppeteer?

DDD
Lepaskan: 2024-10-26 09:03:03
asal
941 orang telah melayarinya

How to Generate PDFs from Single Page Applications with Puppeteer?

Menjana PDF daripada Aplikasi Satu Halaman dengan Puppeteer

Membina aplikasi satu halaman (SPA) memberikan cabaran apabila ia datang untuk menjana PDF kerana kandungan dimuatkan secara dinamik. Artikel ini menangani isu memastikan halaman dimuatkan sepenuhnya sebelum mengeksport PDF.

Pendekatan:

Kunci untuk menyelesaikan masalah ini terletak pada menunggu halaman itu untuk memuatkan sepenuhnya. Daripada meneka dengan kelewatan tetap (mis., tunggu page.waitFor(2000);), kita boleh menggunakan kaedah Puppeteer's page.waitForNavigation().

Pelaksanaan:

Untuk menunggu halaman dimuatkan sebelum menjana PDF, gunakan kod berikut:

<code class="javascript">await page.waitForNavigation({
  waitUntil: 'networkidle0',
});</code>
Salin selepas log masuk

Ini akan menjeda pelaksanaan sehingga halaman selesai dimuatkan dan semua aktiviti rangkaian telah berhenti.

Pertimbangan Tambahan:

  • waitForSelector(): Jika terdapat elemen khusus yang perlu dipaparkan sebelum PDF dijana, pertimbangkan untuk menggunakan halaman .waitForSelector() untuk memastikan keterlihatannya:

    <code class="javascript">await page.waitForSelector('#example', {
      visible: true,
    });</code>
    Salin selepas log masuk
  • waitForNetworkIdle() vs. waitForNetworkIdle2(): Puppeteer menawarkan dua varian waitUntil: networkidle0 dan networkidle2. networkidle0 menunggu semua permintaan rangkaian selesai, manakala networkidle2 menunggu untuk tempoh yang lebih lama, memastikan semua tugasan pasca pemuatan telah diselesaikan.

Kesimpulan:

Dengan menggunakan page.waitForNavigation() dan, secara pilihan, page.waitForSelector(), anda boleh memastikan bahawa PDF anda dijana hanya apabila halaman dimuatkan sepenuhnya, menangkap kandungan dinamik aplikasi satu halaman dengan tepat.

Atas ialah kandungan terperinci Bagaimana untuk Menjana PDF daripada Aplikasi Satu Halaman dengan Puppeteer?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!