在網(wǎng)頁(yè)設(shè)計(jì)中,我們經(jīng)常使用jquery去響應(yīng)鼠標(biāo)的hover事件,和mouseover和mouseout事件有相同的效果,但是這其中其中如何使用bind去綁定hover方法呢?如何用unbind取消綁定的事件呢?
一、如何綁定hover事件
先看以下代碼,假設(shè)我們給a標(biāo)簽綁定一個(gè)click和hover事件:
$(document).ready(function(){
$('a').bind({
hover: function(e) {
// Hover event handler
alert("hover");
},
click: function(e) {
// Click event handler
alert("click");
}
});
});
當(dāng)點(diǎn)擊a標(biāo)簽的時(shí)候,奇怪的事情發(fā)生了,其中綁定的hover事件完全沒(méi)有反應(yīng),綁定的click事件卻可以正常響應(yīng)。
但是如果換一種寫法,比如:
$("a").hover(function(){
alert('mouseover');
}, function(){
alert('mouseout');
})
這段代碼就可以正常的運(yùn)行,難道bind不能綁定hover?
其實(shí)不是,應(yīng)該使用 mouseenter 和 mouseleave 這兩個(gè)事件來(lái)代替,(這也是 .hover() 函數(shù)中使用的事件) 所以完全可以直接像這樣來(lái)引用:
$(document).ready(function(){
$('a').bind({
mouseenter: function(e) {
// Hover event handler
alert("mouseover");
},
mouseleave: function(e) {
// Hover event handler
alert("mouseout");
},
click: function(e) {
// Click event handler
alert("click");
}
});
});
因?yàn)?hover()是jQuery自己定義的事件,是為了方便用戶綁定調(diào)用mouseenter和mouseleave事件而已,它并非一個(gè)真正的事件,所以當(dāng)然不能當(dāng)做.bind()中的事件參數(shù)來(lái)調(diào)用。
二、如何取消hover事件
大家都知道,可以使用unbind函數(shù)去取消綁定的事件,但是只能取消通過(guò)bind綁定的事件,jquery中的hover事件是比較特殊的,如果通過(guò)這種方式去綁定的事件,則無(wú)法取消。
$("a").hover(function(){
alert('mouseover');
}, function(){
alert('mouseout');
})
取消綁定的hover事件的正確方式:
$('a').unbind('mouseenter').unbind('mouseleave');
三、總結(jié)
其實(shí),這些問(wèn)題可以去參看jquery官方的說(shuō)明文檔,只是很少有人去看過(guò),網(wǎng)上的大多數(shù)教程只是講解如何去使用這個(gè)方法,達(dá)到目的即止,并沒(méi)有深入的了解為什么這么寫?
如果你有什么疑惑,歡迎評(píng)論留言。
以上這篇jquery中取消和綁定hover事件的實(shí)現(xiàn)代碼就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考