menu
menu

キーワード検索

 

前月(9月)の人気記事トップ10

  1. ( 1-) 【CSS Tips】CSSだけでドロップダウンメニュー
  2. ( 2-) 【CSS Tips】CSSだけでサイズ可変・スマホ対応のアコーディオン
  3. ( 3-) 【HTML5】スマホサイトの作成・基本編
  4. ( 4-) 【CSS Tips】CSSだけでブロック要素の表示非表示(トグルボタン)
  5. ( 7↑) 【jQuery】表示しているブラウザの高さを取得してCSSのheightに指定
  6. ( 5↓) 【jQuery入門】jQueryで日時を表示
  7. (10↑) 【HTML5】HTML5・ページ作成の基本
  8. ( 9↑) 【MySQL】Windows 10にMySQLをインストール
  9. ( 8↓) 【Mac Tips】MacにInkscapeをインストール
  10. ( 6↓) 【CSS Tips】スマホサイト向け横にスクロールするナビゲーション

【JavaScript】ローカルストレージとクッキー

  • Labs

【JavaScript】ローカルストレージとクッキー

こんにちは(・∀・)

今回はJavaScriptのローカルストレージとクッキーのサンプルをご紹介します。

Contents

  1. ローカルストレージ
  2. クッキー
  3. ローカルストレージとクッキーを両方使用する場合

ローカルストレージとクッキー

クッキーに代わり最近主流となりつつあるローカルストレージですが、未だIEでは未対応です。

今回たまたま別々の案件でローカルストレージとクッキーを使用する機会がありましたのでその覚書をかねて投稿します。

ローカルストレージ

ローカルストレージのサンプルです。

JavaScript

_name = "sample";
function  samplefunc(obj){
localStorage.setItem(_name,obj);
window.location.reload(true);
}
var _value = localStorage.getItem(_name);
if(_value == 0){
_value = 0;
}else if(_value == 1){
_value = 1;
}else{
_value = 0;
}
クッキー

クッキーのサンプルです。

JavaScript

_name = "sample";
function  samplefunc(obj){
document.cookie = _name+"="+obj+"; expires=Fri, 31-Dec-2030 23:59:59 GMT; path=/;";
window.location.reload(true);
}
Cookie = document.cookie+";";
_set1 = Cookie.indexOf(_name);
if(_set1 != -1){
_set2 = Cookie.indexOf("=",_set1);
_set3 = Cookie.indexOf(";",_set2);
_value = Cookie.substring(_set2+1, _set3);
}else{
_value = 0;
}
ローカルストレージとクッキーを両方使用する場合

ローカルストレージとクッキーを同時に使用することはまずないと思いますが、一応両方使用する場合のサンプルです。

JavaScript

document.write('<!--[if !IE]><!-->');
/*ローカルストレージ*/
_name = "sample";
function  samplefunc(obj){
localStorage.setItem(_name,obj);
window.location.reload(true);
}
var _value = localStorage.getItem(_name);
if(_value == 0){
_value = 0;
}else if(_value == 1){
_value = 1;
}else{
_value = 0;
}
document.write('<!--<![endif]-->');

document.write('<!--[if IE]>');
/*クッキー*/
_name = "sample";
function  samplefunc(obj){
document.cookie = _name+"="+obj+"; expires=Fri, 31-Dec-2030 23:59:59 GMT; path=/;";
window.location.reload(true);
}
Cookie = document.cookie+";";
_set1 = Cookie.indexOf(_name);
if(_set1 != -1){
_set2 = Cookie.indexOf("=",_set1);
_set3 = Cookie.indexOf(";",_set2);
_value = Cookie.substring(_set2+1, _set3);
}else{
_value = 0;
}
document.write('<![endif]-->');

条件分岐でIEとそれ以外で振り分けているだけです。

ローカルストレージとクッキーを同時に使用する場合、ローカルストレージ、クッキーの順に書かないと正しく動作しません。


こうやって並べて書くとローカルストレージの書き方はクッキーより簡単になったのがわかりますね。

  • カテゴリー:Labs