Heim > Web-Frontend > js-Tutorial > So vermeiden Sie eine vorzeitige Ausführung von Onclick-Funktionen in JavaScript

So vermeiden Sie eine vorzeitige Ausführung von Onclick-Funktionen in JavaScript

Linda Hamilton
Freigeben: 2024-10-22 07:13:31
Original
1001 Leute haben es durchsucht

How to Avoid Premature Execution of Onclick Functions in JavaScript

Onclick-Funktionsausführung vor dem Klicken: Eine häufige Gefahr in Javascript

In Javascript kann die Onclick-Funktion verwendet werden, um einem HTML-Element beim Klicken eine Aktion zuzuweisen. Entwickler stehen jedoch häufig vor dem Problem, dass die Funktion sofort bei der Elementerstellung ausgeführt wird, noch bevor darauf geklickt wird.

Im bereitgestellten Javascript-Code möchte der Entwickler einen Link erstellen, der beim Klicken eine Funktion auslöst Weiterleitung auf eine neue Seite. Allerdings wird die Onclick-Funktion (secondFunction) aufgrund einer falschen Zuweisungsmethode sofort aufgerufen.

Der Fehler liegt in der Zeile:

<code class="js">sentNode.setAttribute('onclick', secondFunction());</code>
Nach dem Login kopieren

Hier wird die secondFunction() direkt aufgerufen , was bedeutet, dass die Funktion ausgeführt wird, sobald sie definiert ist. Um dieses Problem zu beheben, sollte es wie folgt zugewiesen werden:

<code class="js">sentNode.setAttribute('onclick', secondFunction);</code>
Nach dem Login kopieren

Durch die Referenzierung der Funktion ohne Klammern weist der Code die Funktion selbst zu, nicht ihren Rückgabewert. Dadurch wird sichergestellt, dass die Funktion nur ausgeführt wird, wenn das Onclick-Ereignis auftritt.

Der korrekte Code sollte wie folgt aussehen:

<br>function startFunction() {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">var sentNode = document.createElement('a');
sentNode.setAttribute('href', "#");
sentNode.setAttribute('onclick', secondFunction); // Assign function reference
sentNode.innerHTML = "Sent Items";

// Add new element to parent
var parentNode = document.getElementById('parent');
var childNode = document.getElementById('sendNode');
parentNode.insertBefore(sentNode, childNode);
Nach dem Login kopieren

}

Durch die Übernahme dieser Änderungen wird die Onclick-Funktion entsprechend aufgerufen, wenn auf das Element geklickt wird.

Das obige ist der detaillierte Inhalt vonSo vermeiden Sie eine vorzeitige Ausführung von Onclick-Funktionen in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
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
Neueste Artikel des Autors
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage