Heim > Web-Frontend > js-Tutorial > Beispiele und Vorteile der jQuery on()-Methode

Beispiele und Vorteile der jQuery on()-Methode

巴扎黑
Freigeben: 2017-06-25 10:37:43
Original
1269 Leute haben es durchsucht

Die Verwendung der jquery on()-Methode zum Binden des -Ereignisses ist eine offiziell empfohlene Methode. Folgen Sie als Nächstes dem Editor, um die jquery on()-Methode zu lernen Machen Sie mit. Lass uns lernen

Die jQuery on()-Methode ist eine offiziell empfohlene Methode zum Binden von Ereignissen.

$(selector).on(event,childSelector,data,function,map)
Nach dem Login kopieren

Mehrere zuvor gängige Methoden, die daraus erweitert wurden, umfassen:

bind()

 $("p").bind("click",function(){
    alert("The paragraph was clicked.");
  });
  $("p").on("click",function(){
    alert("The paragraph was clicked.");
  });
Nach dem Login kopieren

Delegate()

$("#p1").on("click","p",function(){
    $(this).css("background-color","pink");
  });
  $("#p2").delegate("p","click",function(){
    $(this).css("background-color","pink");
  });
Nach dem Login kopieren

live()

  $("#p1").on("click",function(){
    $(this).css("background-color","pink");
  });
  $("#p2").live("click",function(){
    $(this).css("background-color","pink");
  });
Nach dem Login kopieren

Die oben genannten drei Methoden funktionieren nach jQuery1.8 Empfohlene Verwendung, offiziell hat die Verwendung der Methode live() in 1.9 eingestellt, daher wird empfohlen, die Methode on() zu verwenden.

Tipp: Wenn Sie die an on() gebundene Methode entfernen müssen, können Sie die Methode off() verwenden.

$(document).ready(function(){
  $("p").on("click",function(){
    $(this).css("background-color","pink");
  });
  $("button").click(function(){
    $("p").off("click");
  });
});
Nach dem Login kopieren

Tipp: Wenn Ihr Event nur eine Operation erfordert, können Sie die one()-Methode

$(document).ready(function(){
  $("p").one("click",function(){
    $(this).animate({fontSize:"+=6px"});
  });
});
Nach dem Login kopieren

trigger ( )Bindung

$(selector).trigger(event,eventObj,param1,param2,...)
$(document).ready(function(){
  $("input").select(function(){
    $("input").after(" Text marked!");
  });
  $("button").click(function(){
    $("input").trigger("select");
  });
});
Nach dem Login kopieren

Mehrere Ereignisse an dieselbe Funktion gebunden

$(document).ready(function(){
 $("p").on("mouseover mouseout",function(){
  $("p").toggleClass("intro");
 });
});
Nach dem Login kopieren

Mehrere Ereignisse an verschiedene Funktionen gebunden

$(document).ready(function(){
 $("p").on({
  mouseover:function(){$("body").css("background-color","lightgray");}, 
  mouseout:function(){$("body").css("background-color","lightblue");}, 
  click:function(){$("body").css("background-color","yellow");} 
 });
});
Nach dem Login kopieren

Benutzerdefinierte Ereignisse binden

$(document).ready(function(){
 $("p").on("myOwnEvent", function(event, showName){
  $(this).text(showName + "! What a beautiful name!").show();
 });
 $("button").click(function(){
  $("p").trigger("myOwnEvent",["Anja"]);
 });
});
Nach dem Login kopieren

Daten an Funktion übergeben

function handlerName(event) 
{
 alert(event.data.msg);
}
$(document).ready(function(){
 $("p").on("click", {msg: "You just clicked me!"}, handlerName)
});
Nach dem Login kopieren

Gilt für nicht erstellte Ereignisse Elemente

$(document).ready(function(){
 $("p").on("click","p",function(){
  $(this).slideToggle();
 });
 $("button").click(function(){
  $("<p>This is a new paragraph.</p>").insertAfter("button");
 });
});
Nach dem Login kopieren

Es gibt mehrere Möglichkeiten, Ereignisse mit jQuery zu binden. Es wird aus zwei Gründen empfohlen, die .on()-Methode zum Binden zu verwenden:

1. Die on()-Methode kann dynamisch zu Seitenelementen hinzugefügte Ereignisse binden.

Verwenden Sie beispielsweise DOM-Elemente, die dynamisch zur Seite hinzugefügt werden Durch die Methode on() muss man sich nicht darum kümmern, wann das Element hinzugefügt wird, das das Ereignis registriert hat, und es muss auch nicht wiederholt gebunden werden. Einige Schüler sind möglicherweise daran gewöhnt, .bind(), .live() oder .delegate() zu verwenden. Wenn Sie sich den Quellcode ansehen, werden Sie feststellen, dass sie tatsächlich die Methode .on() und die Methode .live() aufrufen. Methode ist in jQuery1 Version 9 wurde entfernt.


bind:
function(
 types, data, fn ) {
  return this.on(
 types, null,
 data, fn );
},
live:
function(
 types, data, fn ) {
  jQuery(
this.context
 ).on( types, this.selector,
 data, fn );
  return this;
},
delegate:
function(
 selector, types, data, fn ) {
  return this.on(
 types, selector, data, fn );
}
Nach dem Login kopieren

Verwenden Sie die Methode .off(), um durch .on() gebundene Ereignisse zu entfernen.

2. Die on()-Methode kann die Effizienz der Ereignisbindung verbessern.

In vielen Artikeln wurde die Verwendung von Event-Bubbling und Proxys erwähnt, um die Effizienz der Ereignisbindung zu verbessern Davon sind keine spezifischen Unterschiede aufgeführt. Um dies zu überprüfen, habe ich einen kleinen Test durchgeführt.

Gehen Sie davon aus, dass der Seite 5.000 Li hinzugefügt werden, und testen Sie die Seitenladezeit mithilfe von Chrome Developer Tools-Profilen.

Normale Bindung (nennen wir es so)


$(&#39;li&#39;).click(function(){
  console.log(this)
});
Nach dem Login kopieren

Ausführungszeit des Bindungsprozesses

2013-08-13_190358

Gewöhnliche Bindung entspricht der separaten Registrierung von Klickereignissen auf 5000li, die Speichernutzung beträgt etwa 4,2 MB und die Bindungszeit beträgt etwa 72 ms.

.on()-Bindung


$(document).on(&#39;click&#39;,
&#39;li&#39;,
function(){
  console.log(this)
})
Nach dem Login kopieren

Ausführungszeit des Bindungsprozesses

2013-08-13_191010

.on()-Bindung verwendet Ereignis-Proxy, nur ein Klickereignis wird im Dokument registriert, die Speichernutzung beträgt etwa 2,2 MB und die Bindungszeit beträgt etwa 1 ms.

Das obige ist der detaillierte Inhalt vonBeispiele und Vorteile der jQuery on()-Methode. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage