Rumah > hujung hadapan web > tutorial js > ClearTimeout untuk menghapuskan kemahiran code_javascript contoh berkelip

ClearTimeout untuk menghapuskan kemahiran code_javascript contoh berkelip

WBOY
Lepaskan: 2016-05-16 15:13:02
asal
1346 orang telah melayarinya

Takrif dan penggunaan

Kaedah clearTimeout() boleh membatalkan tamat masa yang ditetapkan oleh kaedah setTimeout().

Tatabahasa

clearTimeout(id_of_settimeout)
Salin selepas log masuk

参数 描述
id_of_settimeout 由 setTimeout() 返回的 ID 值。该值标识要取消的延迟执行代码块。

Keperluan: Apabila tetikus diletakkan pada menu induk, submenu di bawah dipaparkan. Apabila tetikus bergerak dari submenu atau menu induk, submenu harus diruntuhkan. Kesan akhir adalah seperti berikut:

PS: Keperluan ini sangat biasa Pendekatan yang paling biasa adalah untuk menyarangkan elemen Ul di bawah elemen li untuk mengandungi elemen anak. Pendekatan ini boleh dikawal sepenuhnya menggunakan css. Tetapi hari ini submenu dan bar navigasi ini berasingan. Iaitu, blok tag pengepala dipaparkan apabila tetikus berada di atas produk.

<ul class="header-nav">
<li class="nav-item home"><a href="@Url.Action("Index", "Home")">首页</a></li>
<li class="nav-item products" id="header_tags">
<a href="#">产品<span class="icon-caret-down"></span></a>
....
</li>
</ul>
<div class="header-tags">
<ul>
<li>
<img class="screening-img-normal" src="~/Content/static/all.png">
<img class="screening-img-hover" src="~/Content/static/all1.png">
<p>全部</p>
</li>
<li tagid="4">
<img class="screening-img-normal" src="~/Content/static/shafa.png">
<img class="screening-img-hover" src="~/Content/static/shafa1.png">
<p>沙发</p>
</li>
<li tagid="3">
<img class="screening-img-normal" src="~/Content/static/zuoyi.png">
<img class="screening-img-hover" src="~/Content/static/zuoyi1.png">
<p>座椅</p>
</li>
....
</div> 
Salin selepas log masuk

Ini tidak boleh dikawal sepenuhnya dengan css (legar hanya boleh mengawal elemen kanak-kanak atau unsur adik beradik).

/*父子*/
#a:hover #b{display: block} 
/*兄弟*/
#a:hover + #b{display: block} 
Salin selepas log masuk

Situasi di atas memerlukan penggunaan skrip. Ini melibatkan pergerakan masuk dan keluar daripada dua elemen #header_tags dan .header-tags. Apabila tetikus bergerak ke dalam #header_tags, .header-tags dipaparkan Apabila tetikus bergerak ke .header-tags, peristiwa perpindahan #header_tags tidak boleh dicetuskan serta-merta, tetapi teg mesti terus dipaparkan. Submenu akan ditutup hanya selepas tetikus meninggalkan #header_tags dan .header-tags dan tidak masuk lagi.

$(function () {
var tagsTime;
$(document).on('mouseover mouseout', '#header_tags', function(event){
var $headerTagsBox = $('.header-tags');
if (event.type == 'mouseover') {
clearTimeout(tagsTime);
$headerTagsBox.slideDown(300);
}
else if (event.type == 'mouseout') {
tagsTime = setTimeout(function(){
$headerTagsBox.slideUp(200);
}, 200);
}
});
$('.header-tags').hover(function(){
clearTimeout(tagsTime);
},function(){
var $me = $(this);
tagsTime = setTimeout(function(){
$me.slideUp(200);
}, 200);
}); });
Salin selepas log masuk

Jika pemasa tidak dikosongkan dan pelaksanaan tertunda tidak ditambahkan, bar navigasi akan terus berkelip. Tidak boleh klik langsung.

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