ホームページ >ウェブフロントエンド >jsチュートリアル >ブラウザの戻るボタンの押下を確実に検出し、ページ内の戻るボタンのアクションと区別するにはどうすればよいでしょうか?

ブラウザの戻るボタンの押下を確実に検出し、ページ内の戻るボタンのアクションと区別するにはどうすればよいでしょうか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-10 18:19:15640ブラウズ

How Can We Reliably Detect Browser Back Button Presses and Differentiate Them from In-Page Back Button Actions?

クロスブラウザーのブラウザーの戻るボタン検出の実装

戻るボタン押下イベントの検出

ユーザーがブラウザーの戻るボタンを押したかどうかを判断することが課題となります。多くの人が window.onhashchange 関数の使用を提案していますが、この関数はページ内の戻るボタンにも応答するため、ユーザー エクスペリエンスに悪影響を及ぼします。

ページ内の戻るボタンの機能の管理

単一ページ アプリケーションの場合ハッシュ ナビゲーションを利用する場合、ページ内の戻るボタンの動作を制御することが重要です。これを行うには、配列 (window.location.lastthash) を使用して、ユーザーがインターフェイスを移動するときに以前のハッシュを保存します。

ブラウザの戻るボタンとページ内の戻るボタンを区別する

従来の方法は次のとおりです。 window.onbeforeunload と window.onmousedown は、ブラウザーの「戻る」ボタンのクリックを区別するのに効果がないことが判明しました。代わりに、ドキュメントの onmouseover (ドキュメント上にマウスを置いたとき) と onmouseleave (マウスがドキュメントから出たとき) によって切り替えられるフラグ変数が考案されました。

検出メカニズムの利用

window.onhashchange を変更するこのロジックを組み込むには:

Backspace の模倣を防止する戻るボタン

バックスペースが戻るボタン イベントをトリガーしないようにするには、次のスクリプトを実装します。

要約すると、ドキュメントのホバー イベントを利用することで、ブラウザの戻るボタンを効果的に区別できます。クリック数とページ内の戻るボタンの使用状況を確認し、戻るボタンの機能を正確に制御できます。

以上がブラウザの戻るボタンの押下を確実に検出し、ページ内の戻るボタンのアクションと区別するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。