Apabila saya menulis acara kelewatan js hari ini, saya mendapati bahawa menggunakan jquery's $(this) dalam kaedah setTimeout tidak berfungsi Selepas pelbagai ujian, saya akhirnya membuat kesimpulan bahawa pemilih jquery tidak disokong dalam setTimeout. Jadi saya meminta nasihat daripada pakar pembangunan jquery mengenai QQ, dan mereka menyelesaikan masalah itu dengan segera saya akan merekodkannya di sini.
Berikut ialah kod js yang digunakan oleh pengarang semasa melakukan pemprosesan tertunda:
$('.dl_select dt').hover( function(){ clearTimeout(t3); $(this).siblings('dd').css({'display':'block','cursor':'pointer'}); }, function(){ t2=setTimeout(function(){$(this).siblings('dd').css({'display':'none'});},300); } ); $('.dl_select dd').hover( function(){ clearTimeout(t2); $(this).css({'display':'block','cursor':'pointer'}); }, function(){ t3=setTimeout(function(){$(this).css({'display':'none'});},200); } );
Beri perhatian kepada kod dalam setTimeout dalam kod di atas Jika kod ini tiada dalam kaedah ini, tiada masalah dengan sendirinya, tetapi dalam kes ini, ralat akan dilaporkan. Mengenai sebabnya, penulis masih belum mengetahuinya. Selepas mendapat pencerahan oleh netizen, saya menukarnya kepada yang berikut dan ia akan menjadi baik. Berikut ialah kod yang betul:
$('.dl_select dt').hover( function(){ clearTimeout(t3); $(this).siblings('dd').css({'display':'block','cursor':'pointer'}); }, function(){ var $this=$(this).siblings('dd'); t2=setTimeout(function(){$this.css({'display':'none'});},300); } ); $('.dl_select dd').hover( function(){ clearTimeout(t2); $(this).css({'display':'block','cursor':'pointer'}); }, function(){ var $this=$(this); t3=setTimeout(function(){$this.css({'display':'none'});},200); } );
Di atas adalah keseluruhan kandungan artikel ini, saya harap anda semua menyukainya.