Bagaimana untuk Mengesan Peristiwa Cetakan dalam Aplikasi Penyemak Imbas Rentas?

Linda Hamilton
Lepaskan: 2024-11-03 15:22:02
asal
283 orang telah melayarinya

How to Detect Print Events in Cross-Browser Applications?

Mengesan Peristiwa Cetakan dalam Aplikasi Penyemak Imbas Silang

Walaupun penamatan onbeforeprint() dan onafterprint() dalam penyemak imbas bukan IE, terdapat ialah satu cara untuk mencapai kefungsian yang serupa menggunakan window.matchMedia dan window.onbeforeprint/window.onafterprint.

Menggunakan window.matchMedia

Banyak penyemak imbas moden kini menyokong window.matchMedia , yang membolehkan pengesanan perubahan dalam pertanyaan media CSS. Dengan menggabungkan window.matchMedia dengan window.onbeforeprint/window.onafterprint, adalah mungkin untuk mencipta pendekatan silang penyemak imbas untuk mengesan peristiwa cetakan.

Panggil Balik Acara

fungsi berikut boleh digunakan sebagai panggilan balik acara untuk window.matchMedia:

<code class="javascript">window.matchMedia('print').addListener(function(media) {
    if (media.matches) {
        // Print is starting
    } else {
        // Print has ended
    }
});</code>
Salin selepas log masuk

Legacy IE dan Sokongan Firefox

Untuk penyemak imbas yang tidak menyokong window.matchMedia, masih boleh mendengar acara onbeforeprint dan onafterprint secara langsung:

<code class="javascript">$(window).on('beforeprint', beforePrint);
$(window).on('afterprint', afterPrint);</code>
Salin selepas log masuk

Nota: Seperti yang dinyatakan dalam respons yang disediakan, adalah penting untuk mengetahui bahawa window.matchMedia listener boleh menyala beberapa kali semasa kerja cetakan tunggal dalam sesetengah penyemak imbas. Ini mungkin menjejaskan pelaksanaan pengendali acara anda, jadi pertimbangkan tingkah laku ini semasa mereka bentuk logik anda.

Atas ialah kandungan terperinci Bagaimana untuk Mengesan Peristiwa Cetakan dalam Aplikasi Penyemak Imbas Rentas?. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan