目次
JavaScriptはブラウザタブの閉鎖とブラウザの完全閉鎖を区別します
問題の説明
解決
ホームページ ウェブフロントエンド htmlチュートリアル [ブラウザ]タブを閉じることと、JavaScriptを使用してブラウザ全体を閉じることを区別する方法は?

[ブラウザ]タブを閉じることと、JavaScriptを使用してブラウザ全体を閉じることを区別する方法は?

Apr 04, 2025 pm 10:21 PM
windows ブラウザ キーと値のペア sessionstorage

[ブラウザ]タブを閉じることと、JavaScriptを使用してブラウザ全体を閉じることを区別する方法は?

JavaScriptはブラウザタブの閉鎖とブラウザの完全閉鎖を区別します

マルチタブブラウジングの毎日の使用では、ユーザーは単一のタブまたはブラウザ全体を閉じる必要がある場合があります。たとえば、いくつかのアプリケーションシナリオでは、ブラウザが完全に閉じている場合(ログイン情報のクリアなど)、単一のタブを閉じるときはそうではありません。この記事では、JavaScriptを使用してこれら2つの状況を区別し、対応するソリューションを提供する方法について説明します。

問題の説明

開発したWebアプリケーションが、WindowsシステムのChromeブラウザで実行されるとします。要件は、ユーザーがブラウザ全体を閉じるときにログイン情報をクリアし、単一のタブを閉じるときにログイン情報を変更しないようにすることです。この関数を実装する方法は?

解決

HTML5のsessionStorageオブジェクトを使用して、この問題を解決できます。 sessionStorage使用すると、キー価値ペアデータを同じセッションに保存できます。ブラウザを閉じると、 sessionStorageのデータがクリアされ、単一のタブを閉じると他のタブのsessionStorageデータには影響しません。

特定の実装手順は次のとおりです。

  1. ブラウザクローズイベントをリッスンします: beforeunloadイベントを使用して、ブラウザのクローズまたはタブのクローズ操作をリッスンします。

     window.addeventlistener( 'beforeunload'、function(e){
         //ここでログイン情報をクリアするためにコードを追加しますが、ここで直接実行することは、タブを閉じるときにクリアすることにもつながる可能性があることに注意する必要があります。
     });
    ログイン後にコピー
  2. sessionstorageを使用して閉じる動作を区別します。各タブがロードされたら、 sessionStorageアイテムを設定し、閉じたときにアイテムが存在するかどうかを確認します。存在する場合、タブページが閉じられていることを意味します。存在しない場合、ブラウザ全体が閉じられていることを意味します。

     //ページが読み込まれたときにsessionStorageを設定します
     window.addeventlistener( 'load'、function(){
         sessionStorage.setItem( 'tabopen'、 'true');
     });
    
     //閉じたときにSESSIONSTORAGEを確認してください
     window.addeventlistener( 'beforeunload'、function(e){
         if(!sessionStorage.getItem( 'tabopen')){
             //ログイン情報ClearLoginInfo();
         } それ以外 {
             // sessionStorageアイテムsessionStorage.RemoveItem( 'tabopen');
         }
     });
    
     関数ClearLoginInfo(){
         //ここでログイン情報をクリアするためにコードをConsole.log( 'ログイン情報のクリア...');
     }
    ログイン後にコピー

上記の方法を使用して、タブページを閉じることとブラウザの閉鎖を効果的に区別し、ブラウザが完全に閉じているときにログイン情報をクリアする操作を実行できますが、この操作は1つのタブページを閉じるときに実行されません。ブラウザとユーザー設定の特定の実装に応じて、ブラウザによってbeforeunloadイベントがインターセプトまたは遅延する可能性があることに注意する必要があります。信頼性を向上させるために、サーバー側のセッション管理などの他のテクノロジーを考慮することができます。

以上が[ブラウザ]タブを閉じることと、JavaScriptを使用してブラウザ全体を閉じることを区別する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

クラフトCMSのキャッシングの問題を解決する:Wiejeben/Craft-Laravel-Mixプラグインの使用 クラフトCMSのキャッシングの問題を解決する:Wiejeben/Craft-Laravel-Mixプラグインの使用 Apr 18, 2025 am 09:24 AM

CraftCMSを使用してWebサイトを開発する場合、特にCSSやJavaScriptファイルを頻繁に更新する場合、リソースファイルのキャッシュ問題が発生することがよくあります。古いバージョンのファイルがブラウザによってキャッシュされ、ユーザーが最新の変更を表示しないようにすることがあります。この問題は、ユーザーエクスペリエンスに影響を与えるだけでなく、開発とデバッグの難しさを高めます。最近、プロジェクトで同様のトラブルに遭遇し、いくつかの調査の後、プラグインWiejeben/Craft-Laravel-Mixが見つかりました。

Laravelインストールコード Laravelインストールコード Apr 18, 2025 pm 12:30 PM

Laravelをインストールするには、これらの手順を順番に進みます。コンポーザー(MacOS/LinuxとWindows用)インストールLaravelインストーラーをインストールします。

GITソフトウェアのインストール GITソフトウェアのインストール Apr 17, 2025 am 11:57 AM

GITソフトウェアのインストールには、次の手順が含まれています。インストールパッケージをダウンロードしてインストールパッケージを実行して、インストール構成gitインストールgitバッシュ(Windowsのみ)を確認します

Laravelの複雑な属性の関係の問題を解決する方法は? Composerを使用してください! Laravelの複雑な属性の関係の問題を解決する方法は? Composerを使用してください! Apr 17, 2025 pm 09:54 PM

Laravel Developmentでは、特にマルチレベルの属する関係に関しては、複雑なモデル関係に対処することは常に課題でした。最近、私はこの問題に、従来のHasManyThrough関係がニーズを満たすことができず、データクエリが複雑で非効率的になることになっているマルチレベルモデル関​​係を扱うプロジェクトでこの問題に遭遇しました。いくつかの探索の後、私は図書館がStaudenmeir/属していることを発見しました。

ウェブサイトのパフォーマンスを最適化する方法:Minifyライブラリの使用から学んだ経験とレッスン ウェブサイトのパフォーマンスを最適化する方法:Minifyライブラリの使用から学んだ経験とレッスン Apr 17, 2025 pm 11:18 PM

Webサイトの開発の過程で、ページの読み込みを改善することは常に私の最優先事項の1つです。かつて、Webサイトのパフォーマンスを向上させるために、Miniifyライブラリを使用してCSSファイルとJavaScriptファイルを圧縮およびマージしようとしました。しかし、私は使用中に多くの問題と課題に遭遇しました。最終的には、Miniifyがもはや最良の選択ではない可能性があることに気付きました。以下では、私の経験と、Composerを通じてMinifyをインストールして使用する方法を共有します。

GITソフトウェアインストールチュートリアル GITソフトウェアインストールチュートリアル Apr 17, 2025 pm 12:06 PM

GITソフトウェアインストールガイド:Windows、MacOS、またはLinux用のインストーラーをダウンロードするには、公式のGIT Webサイトにアクセスしてください。インストーラーを実行して、プロンプトに従います。 gitの構成:ユーザー名、電子メールを設定し、テキストエディターを選択します。 Windowsユーザー向けに、Git Bash環境を構成します。

Gitソフトウェアとは何ですか? GITソフトウェアの使用方法は? Gitソフトウェアとは何ですか? GITソフトウェアの使用方法は? Apr 17, 2025 pm 12:09 PM

GITは、コードの変更を追跡し、共同開発を可能にするために設計された分散バージョン制御システムです。開発者は、プロジェクトの進化を文書化し、コードの合併を管理し、プロジェクトの履歴を効率的かつ安全な方法で維持することができます。 GITの分散アーキテクチャを通じて、各開発者はプロジェクトの完全なコピーを持ち、中央サーバーと通信せずに共通バージョン制御操作を実行します。

コンポーザーを使用してブラウザのスニッフィングを解決します:whithbrowser/parserライブラリの実用的なアプリケーション コンポーザーを使用してブラウザのスニッフィングを解決します:whithbrowser/parserライブラリの実用的なアプリケーション Apr 17, 2025 pm 11:21 PM

マルチデバイス互換のWebサイトを開発する際に、トリッキーな問題に遭遇しました。ユーザーのブラウザとデバイス情報を正確に識別する方法です。複数の方法を試した後、ユーザーエージェント文字列(ユーザーエージェント)を直接解析することは複雑で信頼性が低く、しばしば誤判断が発生することがわかりました。幸いなことに、Composerを使用してWhatbrowser/Parserライブラリをインストールすることで、この問題をうまく解決しました。

See all articles