Heim > Web-Frontend > js-Tutorial > Wie kann verhindert werden, dass die Seite beim Klicken auf JavaScript-Links nach oben scrollt?

Wie kann verhindert werden, dass die Seite beim Klicken auf JavaScript-Links nach oben scrollt?

DDD
Freigeben: 2024-10-26 09:00:03
Original
370 Leute haben es durchsucht

 How to Prevent Page Scrolling to Top When Clicking JavaScript Links?

Verhindern, dass die Seite nach oben scrollt, wenn auf durch JavaScript ausgelöste Links geklickt wird

Beim Klicken auf einen Link, der mit einem JavaScript-Ereignis verknüpft ist, wie zum Beispiel:

<a href="#">My Link</a>
Nach dem Login kopieren

Die Seite scrollt möglicherweise unbeabsichtigt nach oben. Um dieses Verhalten zu verhindern und gleichzeitig die Funktionalität des Links aufrechtzuerhalten, ziehen Sie die folgenden Lösungen in Betracht:

Option 1: event.preventDefault()

Verwenden Sie die .preventDefault()-Methode des Ereignisobjekts um zu verhindern, dass der Browser seine Standardaktion der Navigation zum Link ausführt.

<code class="javascript">$('#ma_link').click(function($e) {
    $e.preventDefault();
    doSomething();
});

document.getElementById('#ma_link').addEventListener('click', function (e) {
    e.preventDefault();
    doSomething();
})</code>
Nach dem Login kopieren

Option 2: false zurückgeben;

In jQuery wird false von einem Ereignis zurückgegeben Der Handler ruft automatisch event.stopPropagation() und event.preventDefault() auf.

<code class="javascript">$('#ma_link').click(function(e) {
     doSomething();
     return false;
});</code>
Nach dem Login kopieren

Für mehr Browserkompatibilität rufen Sie explizit .preventDefault() auf, wenn Sie rohe DOM-Ereignisse verwenden.

Das obige ist der detaillierte Inhalt vonWie kann verhindert werden, dass die Seite beim Klicken auf JavaScript-Links nach oben scrollt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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