Memahami Perbezaan Antara Tetikus dan Masuk Tetikus Acara
Pengenalan
Apabila berinteraksi dengan elemen web, anda boleh menghadapi situasi di mana anda perlu bertindak balas terhadap pergerakan kursor tetikus. jQuery menyediakan dua peristiwa serupa, tetikus dan tetikus, untuk mengendalikan senario sedemikian. Walau bagaimanapun, terdapat perbezaan yang ketara antara mereka yang boleh memberi kesan kepada kefungsian kod anda.
Menyelidiki Peristiwa
Peristiwa mouseover tercetus apabila kursor tetikus memasuki unsur atau mana-mana unsur anaknya. Ini bermakna selagi kursor berada dalam sempadan elemen, acara itu akan terus menembak berulang kali.
Acara masuk tetikus, sebaliknya, hanya tercetus sekali apabila kursor tetikus masuk. sempadan sesuatu unsur. Tidak kira jika kursor kemudiannya bergerak dalam elemen; acara tidak akan menyala lagi sehingga kursor keluar dan memasuki semula elemen.
Demonstrasi Interaktif
Untuk menggambarkan perbezaan dengan jelas, pertimbangkan kod jQuery berikut:
<code class="js">var i = 0; $("div.overout") .mouseover(function() { i += 1; $(this).find("span").text("mouse over x " + i); }) .mouseout(function() { $(this).find("span").text("mouse out "); }); var n = 0; $("div.enterleave") .mouseenter(function() { n += 1; $(this).find("span").text("mouse enter x " + n); }) .mouseleave(function() { $(this).find("span").text("mouse leave"); });</code>
Kod ini menyediakan pengendali acara untuk dua div: "overout" dengan tetikus dan mouseout, dan "enterleave" dengan mouseenter dan mouseleave. Jika anda menuding tetikus anda di atas "terlalu keluar" dan menggerakkan kursor di dalam sempadannya, teks "tetikus di atas" akan dikemas kini berulang kali. Walau bagaimanapun, jika anda melakukan perkara yang sama pada "enterleave", teks "mouse enter" hanya akan dikemas kini apabila anda mula-mula memasuki div dan bukannya semasa kursor bergerak di dalamnya.
Senario Penggunaan
Berdasarkan perbezaan ini, gunakan tetikus jika anda perlu sentiasa menjejaki pergerakan kursor dalam elemen. Ini berguna untuk senario seperti memaparkan petua alat atau menyerlahkan elemen semasa kursor melayang di atasnya.
Gunakan masuk tetikus apabila anda hanya perlu tahu apabila kursor memasuki atau meninggalkan elemen. Ini sesuai untuk situasi di mana anda ingin mencetuskan tindakan tertentu atau menogol keadaan apabila kursor bergerak masuk atau keluar daripada elemen.
Atas ialah kandungan terperinci ## Apakah Perbezaan Antara Peristiwa `mouseover` dan `mouseenter` dalam jQuery?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!