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

Penyelesaian kepada pemilih jquery yang tidak disokong dalam kemahiran setTimeout_javascript

WBOY
Lepaskan: 2016-05-16 16:01:47
asal
1376 orang telah melayarinya

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); 
  } 
); 
Salin selepas log masuk

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); 
  } 
); 
Salin selepas log masuk

Di atas adalah keseluruhan kandungan artikel ini, saya harap anda semua menyukainya.

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan