jquery中取消和綁定hover事件的實(shí)現(xiàn)代碼
在網(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è)參考,也希望大家多多支持腳本之家。
- 使用jquery給新生的th綁定hover事件的實(shí)例
- 淺談jQuery hover(over, out)事件函數(shù)
- jQuery hover事件簡(jiǎn)單實(shí)現(xiàn)同時(shí)綁定2個(gè)方法
- jQuery實(shí)現(xiàn)hover合成事件的方法
- JQuery中使用on方法綁定hover事件實(shí)例
- jQuery中多個(gè)元素的Hover事件解決方案
- jQuery 鼠標(biāo)經(jīng)過(guò)(hover)事件的延時(shí)處理示例
- jQuery的live()方法對(duì)hover事件的處理示例
- 使用jquery hover事件實(shí)現(xiàn)表格的隔行換色功能示例
- 完美解決jQuery的hover事件在IE中不停閃動(dòng)的問(wèn)題
相關(guān)文章
DIV隨滾動(dòng)條滾動(dòng)而滾動(dòng)的實(shí)現(xiàn)代碼【推薦】
下面小編就為大家?guī)?lái)一篇DIV隨滾動(dòng)條滾動(dòng)而滾動(dòng)實(shí)現(xiàn)代碼【推薦】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-04-04input 和 textarea 輸入框最大文字限制的jquery插件
input 和 textarea 輸入框最大文字限制的jquery插件,需要的朋友可以參考下。2011-10-10基于jQuery的試卷自動(dòng)排版系統(tǒng)實(shí)現(xiàn)代碼
題目提干、選擇題的選項(xiàng)、說(shuō)明文字可以包含多媒體信息(文字、圖片、列表、表格、視頻等等……)。2011-01-01jQuery Easyui Treegrid實(shí)現(xiàn)顯示checkbox功能
本文通過(guò)實(shí)例代碼給大家介紹jQuery Easyui Treegrid實(shí)現(xiàn)顯示checkbox功能的方法,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-08-08jQuery實(shí)現(xiàn)二級(jí)導(dǎo)航菜單的示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)二級(jí)導(dǎo)航菜單的示例,幫助大家理解和制作網(wǎng)頁(yè)特效,感興趣的朋友可以了解下2020-09-09Ajax搜索結(jié)果頁(yè)面下方的分頁(yè)按鈕的生成
前幾天在做項(xiàng)目的時(shí)候 遇到個(gè)小問(wèn)題,就是分頁(yè)結(jié)果的頁(yè)數(shù)太多一般5頁(yè)到10頁(yè)就結(jié)束了可是這個(gè)分頁(yè)結(jié)果有400多頁(yè)的當(dāng)時(shí)就有些抓狂了,后來(lái)想了想模仿搜索引擎的結(jié)果頁(yè)面2012-04-04HTML5使用DeviceOrientation實(shí)現(xiàn)搖一搖功能
這篇文章主要介紹了HTML5使用DeviceOrientation實(shí)現(xiàn)搖一搖功能的相關(guān)資料,需要的朋友可以參考下2015-06-06