ホームページ > ウェブフロントエンド > jsチュートリアル > ポップアップを制御するための SessionStorage と LocalStorage を理解する

ポップアップを制御するための SessionStorage と LocalStorage を理解する

Linda Hamilton
リリース: 2024-12-27 13:41:10
オリジナル
608 人が閲覧しました

Understand SessionStorage and LocalStorage for Controlling Popups

Web サイトのポップアップを管理するために sessionStorage と localStorage を検討する場合、主な違いはデータの保存期間とポップアップの表示方法にあります。

1.セッションストレージ

データ寿命: データはブラウザー セッションの間のみ保持されます。タブまたはブラウザを閉じると、データは消去されます。

使用例:

  • ユーザーが新しいブラウザ セッションでサイトを開くたびにポップアップが再表示される場合は、sessionStorage を使用します。
  • 例: ユーザーがページを更新したり、別のタブでサイトを開いた場合ではなく、ユーザーの現在のセッション中にのみウェルカム ポップアップを表示したいとします。
if (!sessionStorage.getItem('popupDisplayed')) {
    // Display popup
    alert('Welcome to the website!');
    sessionStorage.setItem('popupDisplayed', 'true');
}
ログイン後にコピー

2.ローカルストレージ

データの寿命: データは、ブラウザを閉じた後でも、ユーザーまたはスクリプトによって明示的に消去されるまで保持されます。

使用例:
ユーザーが一度ポップアップを見た後、複数のセッションにわたってポップアップを非表示にしておく必要がある場合は、localStorage を使用します。
例: プロモーション ポップアップを週に 1 回だけ表示するか、ユーザーが閉じた後は二度と表示しないようにしたいとします。

if (!localStorage.getItem('popupDisplayed')) {
    // Display popup
    alert('Check out our special offer!');
    localStorage.setItem('popupDisplayed', 'true');
}
ログイン後にコピー

ポップアップ管理の主な違い:

Feature sessionStorage localStorage
Data Persistence Only for the current session. Persists indefinitely or until cleared.
Scope Tab-specific. Shared across all tabs/windows of the same origin.
When to Use Temporary popups (e.g., session-only welcome message). Persistent control (e.g., don't show again for a returning user).

決定基準:

  • 短期ポップアップ ロジック: 新しいセッションでポップアップを再度表示したい場合は、sessionStorage を使用します。
  • 永続的なポップアップ ロジック: ブラウザまたはタブを閉じた後でもポップアップ ロジックを永続化する必要がある場合は、localStorage を使用します。

より複雑な状況では、カスタム ロジックを使用して両方のストレージを混合することもできます (例: 1 週間のセッションベース)。

以上がポップアップを制御するための SessionStorage と LocalStorage を理解するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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