Heim >Web-Frontend >js-Tutorial >Was bedeutet javascript:void(0) und der Unterschied zwischen den Fähigkeiten href=# und href=javascriptvoid(0)_javascript?
void ist ein Operator in Javascript, der angibt, dass ein Ausdruck ausgewertet werden soll, aber keinen Wert zurückgibt.
Das Verwendungsformat des Void-Operators lautet wie folgt:
1. javascript:void (Ausdruck)
2. javascript:void expression
Ausdruck ist ein auszuwertender Javascript-Standardausdruck. Die Klammern außerhalb des Ausdrucks sind optional, es empfiehlt sich jedoch, sie zu schreiben.
Sie können einen Hyperlink mit dem Void-Operator angeben. Der Ausdruck wird ausgewertet, es wird jedoch nichts in das aktuelle Dokument geladen.
Beispiel – Durch Klicken auf einen Hyperlink wird nicht gesprungen
1:6b0da6d38e340e6a590cff29d8e276f55db79b134e9f6b82c0b36e0489ee08ed
2:0408054196e655f677973fb4d7c998655db79b134e9f6b82c0b36e0489ee08ed
3:6c83c0caad21deef893bd2b64d8d5a5c5db79b134e9f6b82c0b36e0489ee08ed
4:755146b0f224288ff1f9517809ac46ba5db79b134e9f6b82c0b36e0489ee08ed
Nachdem Sie auf den Link geklickt haben, scrollt die Seite nach oben. # Der Standardankerpunkt ist #TOP (bei tatsächlichen Tests wurde festgestellt, dass die Bildlaufleiste nur nach oben scrollt). ein toter Link. Sie alle stellen einen toten Link dar. Er springt und kehrt nicht nach oben zurück.
Beispiel – Warum springt location.href nicht automatisch?
<a href="javascript:void(0)" onclick="delete('123')">删除</a> function delete(id){ if(confirm("确实要删除[为什么location.href不自动跳转?]吗?")) { location.href="/delete.jsp?id=" + id; } }
Egal wie Sie den obigen Code überprüfen, es gibt kein Problem, und location.href="/delete.jsp?id=" id; funktioniert an anderen Stellen gut.
Der Grund dafür ist, dass void(0) den Code geändert hat in:
<a href="javascript:delete('123')">删除</a>function delete(id) { if(confirm("确实要删除[为什么location.href不自动跳转?]吗?")) { location.href="/delete.jsp?id=" + id; } }
Wir haben festgestellt, dass die Seite sofort gesprungen ist und die entsprechenden Daten normal gelöscht werden konnten.
Da void ein Operator ist, wird ein Ausdruck berechnet, aber kein Wert zurückgegeben. Natürlich wird der Inhalt der aktuellen Seite nicht geändert und es wird nicht normal gesprungen.
Beschreibung
Dervoid-Operator wertet einen Ausdruck aus und gibt undefiniert zurück. Dieser Operator ist am nützlichsten, wenn Sie einen Ausdruck auswerten möchten, das Ergebnis aber nicht für den Rest des Skripts sichtbar sein soll.
Die direkte Verwendung von javascript:void(0) für Links (href) kann im IE zu einigen Problemen führen, z. B. dazu, dass die GIF-Animation nicht mehr abgespielt wird usw. Daher ist die sicherste Methode die Verwendung von „#“. Um zu verhindern, dass nach dem Klicken auf den Link zum Anfang der Seite gesprungen wird, kann das onclick-Ereignis „false“ zurückgeben.
PS: Der Unterschied zwischen href=# und href=javascriptvoid(0)
#" enthält eine Standortinformation
Der Standardankerpunkt ist #top, also der obere Rand der Webseite
Und javascript:void(0) stellt lediglich einen toten Link dar
Aus diesem Grund ist die Seite manchmal sehr lang und der Browsing-Link lautet eindeutig #, springt aber zum Seitenanfang
Und javascript:void(0)
Dies ist nicht der Fall, daher ist es am besten, beim Aufruf des Skripts void(0)
zu verwenden.
Oder 7ce8961e120a815eeb46b3f04acc755f 414cf55ed2331ac9b67428e512c358bc
Mehrere Möglichkeiten, Links in neuen Fenstern zu öffnen
<script> function openWin(tag,obj) { obj.target="_blank"; obj.href = "Web/Substation/Substation.aspx?stationno="+tag; obj.click(); } </script> <a href="javascript:void(0)" onclick="openWin(3,this)">LINK_TEST</a> window.location.href=""
Wenn es ein # ist, springt es nach oben. Mehrere Lösungen aus persönlichen Favoriten:
1:6b0da6d38e340e6a590cff29d8e276f55db79b134e9f6b82c0b36e0489ee08ed 2:0408054196e655f677973fb4d7c998655db79b134e9f6b82c0b36e0489ee08ed 3:6c83c0caad21deef893bd2b64d8d5a5c5db79b134e9f6b82c0b36e0489ee08ed 4:755146b0f224288ff1f9517809ac46ba5db79b134e9f6b82c0b36e0489ee08ed 5:84c8ecde5320398c03be1686cf845b0554bdf357c58b8a65c66d7c19c8e4d114 (Es scheint, dass es nicht in FF angezeigt werden kann)
--------------------------------- --- --------------------------------
Der obige Inhalt stellt Ihnen vor, was javascript:void(0) bedeutet und welchen Unterschied zwischen href=# und href=javascriptvoid(0) besteht.