Dengan peningkatan berterusan fungsi halaman web, semakin banyak halaman web perlu memantau dan memproses tingkah laku pengguna. Antaranya, salah satu tingkah laku yang paling biasa ialah pengguna menutup tetingkap penyemak imbas. Walau bagaimanapun, pelaksanaan fungsi ini mungkin berbeza sedikit dalam pelayar yang berbeza. Hari ini, mari kita bincangkan cara jQuery mengendalikan acara penutupan tetingkap dalam Google Chrome.
1. Acara memunggah tetingkap
Acara menutup tetingkap sebenarnya boleh direalisasikan melalui acara memunggah objek tetingkap. Peristiwa pemunggahan dicetuskan apabila tetingkap atau bingkai dipunggah. Berikut ialah contoh menggunakan JavaScript tulen untuk melaksanakan acara penutupan tetingkap:
window.onunload = function() { alert("窗口即将关闭!"); }
Dalam contoh ini, apabila tetingkap penyemak imbas ditutup, kotak gesaan akan muncul untuk mengingatkan pengguna tentang acara tersebut. Walau bagaimanapun, terdapat masalah dengan menggunakan acara pemunggahan: ia juga dicetuskan apabila penyemak imbas melompat ke halaman lain. Oleh itu, jika mana-mana pautan dalam halaman diklik, acara pemunggahan juga akan dicetuskan. Ini sering menyebabkan masalah kepada pengaturcara.
2. Acara memunggah jQuery
Untuk menyelesaikan masalah acara memunggah, jQuery menyediakan acara memunggahnya sendiri. Ia hanya menyala apabila tetingkap penyemak imbas ditutup, bukan apabila penyemak imbas melompat ke halaman lain. Berikut ialah contoh penggunaan jQuery untuk melaksanakan acara tutup tetingkap:
$(window).on("unload", function() { alert("窗口即将关闭!"); });
Dalam contoh ini, pemilih $(window) memilih objek tetingkap, dan kemudian menggunakan kaedah on() untuk mengikat acara bongkar muat. Apabila tetingkap ditutup, kotak gesaan akan muncul.
3. Pemprosesan khas Google Chrome
Walaupun acara pemunggahan jQuery boleh berfungsi seperti biasa dalam kebanyakan penyemak imbas, dalam Google Chrome, terdapat situasi khas yang memerlukan perhatian.
Dalam Google Chrome, jika halaman web mengandungi sebarang pemalam yang sedang berjalan (seperti Flash), apabila pengguna menutup penyemak imbas, proses di mana pemalam itu berada tidak akan keluar serta-merta, tetapi akan ambil sedikit masa untuk tamat. Dalam kes ini, acara pemunggahan mungkin tidak dicetuskan.
Untuk menyelesaikan masalah ini, kita boleh menggunakan acara beforeunload. Acara ini dicetuskan sebelum tetingkap ditutup dan acara penutupan tetingkap boleh dibatalkan dengan mengembalikan rentetan. Berikut ialah contoh menggunakan acara beforeunload dalam Google Chrome:
$(window).on("beforeunload", function() { return "确定要离开吗?"; });
Dalam contoh ini, apabila pengguna menutup penyemak imbas, kotak gesaan akan muncul bertanyakan pengguna jika mereka pasti mahu pergi. Jika pengguna mengklik butang "Batal", penyemak imbas tidak akan ditutup.
Perlu diambil perhatian bahawa jika halaman web mengandungi pemalam yang sedang berjalan, dalam Google Chrome, walaupun acara sebelum nyahmuat digunakan, peristiwa penutupan tetingkap tidak boleh ditangkap dengan tepat sepenuhnya. Oleh itu, dalam amalan, anda harus cuba mengelakkan sebarang pemalam yang sedang berjalan dalam halaman web anda.
Kesimpulan
Melalui perbincangan di atas, kita boleh membuat kesimpulan berikut:
Ringkasnya, melaksanakan acara penutupan tetingkap memerlukan pemprosesan khas untuk persekitaran penyemak imbas yang berbeza. Dalam amalan, kita harus memilih kaedah pengendalian acara yang sesuai mengikut situasi tertentu dan menguji sepenuhnya pelbagai situasi.
Atas ialah kandungan terperinci Mari kita bincangkan tentang acara penutup jQuery dan Google Chrome. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!