ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript リンクをクリックしたときに不要なページがスクロールされるのを防ぐにはどうすればよいですか?

JavaScript リンクをクリックしたときに不要なページがスクロールされるのを防ぐにはどうすればよいですか?

Susan Sarandon
リリース: 2024-10-26 02:11:02
オリジナル
206 人が閲覧しました

How Can I Prevent Unwanted Page Scrolling When Clicking JavaScript Links?

JavaScript リンクのクリック時のページ スクロールの防止

Web ページに JavaScript イベントをトリガーすると同時に新しいページに移動するリンクが含まれている場合、ページが一番上までスクロールするという、望ましくない副作用が発生する可能性があります。この動作により、ユーザー フローが中断され、Web サイトの意図した機能が中断される可能性があります。

このスクロール動作を防ぐには、リンクのクリックに関連付けられたデフォルトのアクション (ターゲット URL へのリダイレクト) を無効にする必要があります。これを実現するための 2 つの効果的な方法を次に示します。

オプション 1:event.preventDefault()

このメソッドを使用すると、.preventDefault を呼び出すことでデフォルトのアクションを明示的に防止できます。イベント ハンドラーに渡されるイベント オブジェクトの () メソッド。

  • jQuery:

    <code class="js">$('#ma_link').click(function($e) {
      $e.preventDefault();
      doSomething();
    });</code>
    ログイン後にコピー
  • addEventListener (生 DOM):

    <code class="js">document.getElementById('#ma_link').addEventListener('click', function (e) {
      e.preventDefault();
      doSomething();
    })</code>
    ログイン後にコピー

オプション 2: return false;

jQuery では、イベント ハンドラーは、.stopPropagation() メソッドと .preventDefault() メソッドの両方を自動的に呼び出します。これは、デフォルトのリンク動作を防ぐ別の方法を提供します。

<code class="js">$('#ma_link').click(function(e) {
     doSomething();
     return false;
});</code>
ログイン後にコピー

生の DOM イベント (jQuery ではない) を使用している場合、false を返すことは最新のブラウザでも機能しますが、古いブラウザとの互換性を最大限に高めるために、 .preventDefault().

を明示的に呼び出すことをお勧めします。

以上がJavaScript リンクをクリックしたときに不要なページがスクロールされるのを防ぐにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート