Rumah  >  Artikel  >  hujung hadapan web  >  Penyelesaian kepada pemilih jquery yang tidak disokong dalam kemahiran setTimeout_javascript

Penyelesaian kepada pemilih jquery yang tidak disokong dalam kemahiran setTimeout_javascript

WBOY
WBOYasal
2016-05-16 16:01:471315semak imbas

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.

Kenyataan:
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