Heim  >  Artikel  >  Web-Frontend  >  jquery: Implementierungscode zum Abbrechen und Binden des Hover-Ereignisses

jquery: Implementierungscode zum Abbrechen und Binden des Hover-Ereignisses

黄舟
黄舟Original
2017-06-26 11:11:391308Durchsuche

Der folgende Editor liefert Ihnen einen Implementierungscode zum Abbrechen und Binden des Hover--Ereignisses in jquery. Der Herausgeber findet es ziemlich gut, deshalb teile ich es jetzt mit Ihnen und gebe es als Referenz. Folgen wir dem Editor und werfen wir einen Blick darauf

Im Webdesign verwenden wir häufig JQuery, um auf Maus-Hover-Ereignisse zu reagieren, die den gleichen Effekt haben wie Mouseover- und Mouseout-Ereignisse, aber wie bindet man sie, um sie zu binden. Was ist damit? die Hover-Methode? Wie verwende ich Unbind, um die Bindung eines Ereignisses aufzuheben?

1. So binden Sie das Hover-Ereignis

Schauen Sie sich zunächst den folgenden Code an tag:

$(document).ready(function(){
  $('a').bind({
    hover: function(e) {
      // Hover event handler
      alert("hover");
    },
    click: function(e) {
      // Click event handler
      alert("click");
    }
  });
});

Wenn auf ein Tag geklickt wird, passiert etwas Seltsames. Das gebundene Hover-Ereignis reagiert überhaupt nicht, aber das gebundene Klick-Ereignis reagiert normal.

Aber wenn Sie die Schreibmethode ändern, zum Beispiel:

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

Dieser Code kann nicht normal ausgeführt werden. Kann die Bindung nicht an den Schwebezustand gebunden werden?

Tatsächlich nein, Sie sollten stattdessen die beiden Ereignisse Mouseenter und Mouseleave verwenden (dies ist auch das Ereignis, das in der Funktion .hover() verwendet wird), damit Sie es direkt wie folgt tun können dieses Zitat :

$(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");
    }
  });
});

Weil .hover() ein von jQuery selbst definiertes Ereignis ist. Es dient nur der Bequemlichkeit der Benutzer, Mouseenter- und Mouseleave-Ereignisse zu binden und aufzurufen Es handelt sich nicht um ein echtes Ereignis, daher kann es natürlich nicht als mit Ereignisparametern in .bind() aufgerufen angesehen werden.

2. So stornieren Sie das Hover-Ereignis

Wie wir alle wissen, können Sie die Funktion zum Aufheben der Bindung verwenden, um gebundene Ereignisse abzubrechen, Sie können jedoch nur durchgebundene Ereignisse stornieren bind. Das Hover-Ereignis in jquery ist etwas ganz Besonderes. Wenn das Ereignis auf diese Weise gebunden ist, kann es nicht abgebrochen werden.

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

Der richtige Weg, das gebundene Hover-Ereignis abzubrechen:

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

3 🎜>Tatsächlich können Sie sich bei diesen Problemen auf die offizielle Dokumentation von jquery beziehen, aber nur wenige Leute haben sie gelesen. Die meisten Tutorials im Internet erklären nur, wie diese Methode verwendet wird, und erreichen nur das Ziel, ohne in die Tiefe zu gehen Verstehen Sie, warum Sie so schreiben?

Wenn Sie Fragen haben, hinterlassen Sie bitte einen Kommentar.

Das obige ist der detaillierte Inhalt vonjquery: Implementierungscode zum Abbrechen und Binden des Hover-Ereignisses. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn