Rumah >hujung hadapan web >Soal Jawab bahagian hadapan >jquery menentukan sama ada bar skrol berhenti
Dalam halaman web, penggunaan bar skrol selalunya berkaitan dengan interaksi dinamik. Walau bagaimanapun, dalam beberapa kes kita perlu tahu sama ada bar skrol telah berhenti menatal. Artikel ini akan memperkenalkan kaedah untuk menggunakan jQuery untuk menentukan sama ada bar skrol telah berhenti.
Mula-mula, mari semak cara menggunakan jQuery untuk mengesan acara tatal. Dalam jQuery, anda boleh menggunakan kod berikut untuk mengikat acara tatal:
$(window).scroll(function(){ //scroll event code here });
Dalam contoh ini, kami menggunakan $(window)
untuk memilih keseluruhan halaman web, dan kemudian menggunakan kaedah .scroll()
untuk mengikat acara tatal. Apabila pengguna menatal halaman, acara ini dicetuskan dan kod yang sepadan dilaksanakan.
Kami memerlukan beberapa kod tambahan apabila mengesan sama ada bar skrol telah berhenti. Secara khusus, kita perlu menggunakan kaedah setTimeout()
dan pembolehubah untuk merekodkan kedudukan bar skrol, dan kemudian bandingkannya dengan kedudukan baharu untuk menentukan sama ada bar skrol telah berhenti. Berikut ialah contoh kod:
//声明变量 var position = $(window).scrollTop(); var timeout = null; $(window).scroll(function() { //清除定时器 clearTimeout(timeout); //设置定时器 timeout = setTimeout(function() { //判断是否停止滚动 if ($(window).scrollTop() == position) { console.log("滚动条已停止"); //停止滚动后执行的代码 } //更新位置 position = $(window).scrollTop(); }, 50); });
Dalam kod ini, kami mencipta dua pembolehubah: position
untuk merekodkan kedudukan bar skrol semasa dan timeout
untuk menyimpan pemasa yang akan kami tetapkan. Apabila pengguna menatal halaman, kami mula-mula mengosongkan pemasa yang ditetapkan sebelum ini dan kemudian menetapkan pemasa baharu menggunakan kaedah setTimeout()
. Pemasa ini dilaksanakan selepas 50 milisaat, dan jika kedudukan bar skrol berbeza daripada sebelumnya, kami mengemas kini nilai position
. Jika bar skrol berada dalam kedudukan yang sama seperti sebelumnya, kami mengeluarkan mesej yang menunjukkan bahawa bar skrol telah berhenti.
Satu perkara yang perlu diambil perhatian ialah kita perlu melakukan pengiraan dalam pemasa untuk memastikan pengguna telah berhenti menatal. Dalam contoh ini, kami menggunakan selang 50 milisaat. Nombor ini boleh dilaraskan mengikut kes demi kes untuk memastikan ketepatan dan prestasi.
Setakat ini, kami telah berjaya menggunakan jQuery untuk menentukan sama ada bar skrol telah berhenti. Dalam aplikasi praktikal, kita boleh menambah kod selanjutnya mengikut keperluan untuk mencapai fungsi yang lebih kompleks.
Atas ialah kandungan terperinci jquery menentukan sama ada bar skrol berhenti. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!