HTML5 WebStorageのまとめ.
WebStorageを使うと,Key-Valueペアで,ブラウザ(ローカル環境)にデータが保存できる.
Cookie vs WebStorage
WebStorageはsessionStorage・localStorageの2種類ある.
以下の特徴がある.
各ストレージのデータ量上限は,ブラウザによって異なる.
下記に詳しく解説されている.
別ウィンドウでのデータ共有 | データの有効期限 | |
---|---|---|
クッキー | ○ | 指定期限まで有効 |
sessionStorage | × | ウィンドウやタブを閉じるまで有効 |
localStorage | ○ | 永続的に有効 |
実装
localStorageを用いて実装してみた.
cacheHandler.jsでキャッシュを扱う処理を用意.
main.jsで,キャッシュにデータがなければ,取得し,キャッシュに保存する.
[code language="javascript" title="cacheHandler.js"]<br />/**<br /><%%KEEPWHITESPACE%%> * コンストラクタです.<br /><%%KEEPWHITESPACE%%> * @constructor<br /><%%KEEPWHITESPACE%%> */<br />function CacheHandler() {<br />}<br /><br />/**<br /><%%KEEPWHITESPACE%%> * HTML5 localStorage からキーに対応するデータを取得します.<br /><%%KEEPWHITESPACE%%> * @param storageKey キー<br /><%%KEEPWHITESPACE%%> * @returns {*} JSON<br /><%%KEEPWHITESPACE%%> */<br />CacheHandler.prototype.getCache = function (storageKey) {<br /><%%KEEPWHITESPACE%%> return angular.fromJson(sessionStorage.getItem(storageKey));<br />};<br /><br />/**<br /><%%KEEPWHITESPACE%%> * HTML5 localStorage にデータを格納します.<br /><%%KEEPWHITESPACE%%> * @param storageKey キー<br /><%%KEEPWHITESPACE%%> * @param data JSON<br /><%%KEEPWHITESPACE%%> */<br />CacheHandler.prototype.setCache = function (storageKey, data) {<br /><%%KEEPWHITESPACE%%> sessionStorage.setItem(storageKey, angular.toJson(data));<br />};<br /><br />/**<br /><%%KEEPWHITESPACE%%> * HTML5 localStorage のデータを削除します.<br /><%%KEEPWHITESPACE%%> * @param storageKey キー<br /><%%KEEPWHITESPACE%%> */<br />CacheHandler.prototype.removeCache = function (storageKey) {<br /><%%KEEPWHITESPACE%%> sessionStorage.removeItem(storageKey);<br />};<br />[/code]
[code language="javascript" title="main.js"]<br />// ページ読み込み時に実行したい処理<br />$().ready(function () {<br /><%%KEEPWHITESPACE%%> var key = &quot;dataKey&quot;;<br /><%%KEEPWHITESPACE%%> var cacheHandler = new CacheHandler();<br /><br /><%%KEEPWHITESPACE%%> // キャッシュからデータを取得する<br /><%%KEEPWHITESPACE%%> var data = cacheHandler.getCache(key);<br /><br /><%%KEEPWHITESPACE%%> // キャッシュがあればそれを返す<br /><%%KEEPWHITESPACE%%> if (!data) {<br /><%%KEEPWHITESPACE%%> // データを取得する処理<br /><%%KEEPWHITESPACE%%> data = &quot;どこかから取得したデータ&quot;;<br /><%%KEEPWHITESPACE%%> // キャッシュに格納する<br /><%%KEEPWHITESPACE%%> cacheHandler.setCache(key, data);<br /><%%KEEPWHITESPACE%%> }<br /><br /><%%KEEPWHITESPACE%%> return data;<br />});<br />[/code]
これだけの実装だとキャッシュが最新状態かどうか判断できないので,
キャッシュ元データが最新版か確認し,そうでなければ再び取得などの処理が必要.
また,キャッシュの削除処理もどこかに組み込みたい.