ホームページ >ウェブフロントエンド >htmlチュートリアル >sessionStorage の実​​行可能な代替手段

sessionStorage の実​​行可能な代替手段

WBOY
WBOYオリジナル
2024-01-13 12:03:19668ブラウズ

sessionStorage の実​​行可能な代替手段

sessionStorage の代替手段として考えられるものは何ですか?

sessionStorage は、ブラウザによって提供されるストレージ メカニズムで、一時的なセッション データを同じウィンドウまたはタブに保存できます。ただし、sessionStorage には、データがセッションに保存されること、ウィンドウまたはタブを閉じるとデータが消去されること、ウィンドウまたはタブ間でデータを共有できないことなど、いくつかの制限があります。したがって、より柔軟でグローバルなデータ ストレージ ソリューションが必要な場合は、他の代替手段を検討する必要があります。

  1. localStorage の使用

localStorage は sessionStorage よりも強力で、異なるウィンドウまたはタブ間でデータを共有でき、データは期限切れになりません。 sessionStorage と同様に、localStorage もブラウザーによって提供される API であり、次のコード例で使用できます。

// データの保存
localStorage.setItem('key', 'value');

// データの取得
var value = localStorage.getItem('key');

// データの削除
localStorage.removeItem('key');

/ / すべてのデータをクリア
localStorage.clear();

  1. cookie を使用する

localStorage に加えて、Cookie も一般的なデータ ストレージ ソリューションです。 Cookie には、各ドメイン名での Cookie の数の制限や Cookie のサイズの制限など、いくつかの制限がありますが、クロスドメインの特性があり、異なるドメイン名でデータを共有できます。

// データを保存し、cookie にデータを書き込みます
document.cookie = 'key=value;expires=Thu, 18 Dec 2023 12:00:00 UTC; path=/';

// データの取得、Cookie からのデータの読み取り
function getCookie(name) {

var cookies = document.cookie.split(';');
for (var i = 0; i < cookies.length; i++) {
    var cookie = cookies[i].trim();
    if (cookie.substring(0, name.length + 1) === (name + '=')) {
        return decodeURIComponent(cookie.substring(name.length + 1));
    }
}
return '';

}

var value = getCookie('key');

// データを削除し、Cookie の有効期限を現在時刻より前に設定します
function deleteCookie(name) {

document.cookie = name + '=; expires=Thu, 01 Jan 1970 00:00:01 GMT; path=/';

}

deleteCookie('key');

  1. IndexedDB の使用
#IndexedDB は、ブラウザーに提供される高度なデータベースであり、ブラウザーに大量の構造化データを保存できます。 localStorage や Cookie とは異なり、IndexedDB はより複雑なオブジェクトを保存でき、トランザクションやインデックスなどの機能をサポートします。以下は IndexedDB を使用したコード例です:

// データベースを開きます

var request = window.indexedDB.open('myDatabase', 1);

request.onupgradeneeded = function ( イベント) {

var db = event.target.result;
var objectStore = db.createObjectStore('myObjectStore', { keyPath: 'id' });

};

request.onsuccess = function(event) {

var db = event.target.result;
var transaction = db.transaction(['myObjectStore'], 'readwrite');
var objectStore = transaction.objectStore('myObjectStore');

// 存储数据
var request = objectStore.add({ id: 1, name: 'value' });

request.onsuccess = function(event) {
    console.log('Data stored successfully.');
};

// 获取数据
var getRequest = objectStore.get(1);

getRequest.onsuccess = function(event) {
    var value = getRequest.result.name;
};

// 删除数据
var deleteRequest = objectStore.delete(1);

deleteRequest.onsuccess = function(event) {
    console.log('Data deleted successfully.');
};

};

    サードパーティを使用するライブラリ
上記のネイティブ ストレージ ソリューションに加えて、データをより便利に保存できる次のようなサードパーティ ライブラリもあります。アプリケーションのステータスを管理するための JavaScript ライブラリは、グローバル ストアを作成することでデータを保存できます。

RxJS: 非同期データ ストリームを処理するためのライブラリ。データを保存するグローバルな監視可能なオブジェクトを作成するために使用できます。
  • MobX: グローバルストアを作成してデータを保存・監視できる状態管理用ライブラリ。
  • 上記は、sessionStorage に代わる実現可能なソリューションのほんの一部であり、選択する具体的なソリューションは、実際のニーズとアプリケーション シナリオによって異なります。

以上がsessionStorage の実​​行可能な代替手段の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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