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