jquery中取消和綁定hover事件的實(shí)現(xiàn)代碼

字號(hào):


    在網(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è)參考