国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jquery中取消和綁定hover事件的實現代碼

2019-11-20 09:49:34
字體:
來源:轉載
供稿:網友

在網頁設計中,我們經常使用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標簽的時候,奇怪的事情發生了,其中綁定的hover事件完全沒有反應,綁定的click事件卻可以正常響應。

但是如果換一種寫法,比如:

$("a").hover(function(){  alert('mouseover');}, function(){  alert('mouseout');})

這段代碼就可以正常的運行,難道bind不能綁定hover?

其實不是,應該使用 mouseenter 和 mouseleave 這兩個事件來代替,(這也是 .hover() 函數中使用的事件) 所以完全可以直接像這樣來引用:

$(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()中的事件參數來調用。

二、如何取消hover事件

大家都知道,可以使用unbind函數去取消綁定的事件,但是只能取消通過bind綁定的事件,jquery中的hover事件是比較特殊的,如果通過這種方式去綁定的事件,則無法取消。

$("a").hover(function(){  alert('mouseover');}, function(){  alert('mouseout');})

取消綁定的hover事件的正確方式:

$('a').unbind('mouseenter').unbind('mouseleave');

三、總結

其實,這些問題可以去參看jquery官方的說明文檔,只是很少有人去看過,網上的大多數教程只是講解如何去使用這個方法,達到目的即止,并沒有深入的了解為什么這么寫?

如果你有什么疑惑,歡迎評論留言。

以上這篇jquery中取消和綁定hover事件的實現代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商城县| 永寿县| 苍溪县| 隆安县| 衡水市| 安丘市| 紫金县| 青龙| 泰兴市| 鹿邑县| 红安县| 黑河市| 哈尔滨市| 株洲县| 东山县| 晋中市| 灵石县| 绥宁县| 绍兴县| 南昌市| 黄梅县| 浦北县| 故城县| 深水埗区| 柞水县| 博客| 辽宁省| 东乌| 湖北省| 晋江市| 郎溪县| 辽源市| 满城县| 丰宁| 汉川市| 海丰县| 竹北市| 山丹县| 浙江省| 高唐县| 凌云县|