Closed yudukiak closed 6 years ago
$(function(){
// --------------------------------------------------------
// JavaScriptによるcookieが有効か無効かの判定
// https://qiita.com/tatsuyankmura/items/8e09cbd5ee418d35f169
// --------------------------------------------------------
var setCookie = function(cookieName, value, expire){
var cookie = cookieName+"="+value+";";
if(Number(expire) > 0){cookie += 'expires='+expire;}
document.cookie = cookie;
}
var getCookie = function(cookieName){
var l = cookieName.length+1;
var cookieAry = document.cookie.split("; ");
var str = "";
for(i=0,j=cookieAry.length; i<j; i++){
if(cookieAry[i].substr(0,l) === cookieName+"="){
str = cookieAry[i].substr(l,cookieAry[i].length);
break;
}
}
return str;
}
// --------------------------------------------------------
// 処理
// --------------------------------------------------------
setCookie('ck_cookie', true);
var checkCookie = getCookie('ck_cookie');
if(checkCookie){
//cookie 有効
var checkCookie = getCookie('st_key');
console.log(checkCookie);
} else {
//cookie 無効
alert('Cookieが無効になっています。\n有効にすると設定内容を保存できます。');
}
$('#save_json').on('click', function (){
// Cookieを保存
var expire = new Date(Date.now()+1*365*24*60*60*1000); // 365日保持させる
var settingJson = '{"type1":[{"type":"type1","rarity":"ssr","id":"2040244000","rank":"rank0"}],"type2":[{"type":"type2","rarity":"ssr","id":"2040243000","rank":"rank0"}],"type3":[{"type":"type3","rarity":"ssr","id":"2040237000","rank":"rank0"}],"type4":[{"type":"type4","rarity":"ssr","id":"2040239000","rank":"rank0"}],"type5":[{"type":"type5","rarity":"ssr","id":"2040242000","rank":"rank0"}],"type6":[{"type":"type6","rarity":"ssr","id":"2040238000","rank":"rank0"}],"type7":[{"type":"type1","rarity":"ssr","id":"2040240000","rank":"rank0"}],"type8":[{"type":"type2","rarity":"ssr","id":"3040138000","rank":"rank0"}],"type9":[{"type":"Djeeta","rarity":"c1","id":"120001_wa","rank":"rank0"}],"setting":[{"chara":true,"text":"いろはにほへとちりぬるをわかよたれそつねならむうゐのおくやまけふこえてあさきゆめみしゑひも","user":"1234567890"}]}';
var settingJson_e = encodeURIComponent(settingJson);
setCookie('st_key', settingJson_e, expire);
});
$('#delete_json').on('click', function (){
setCookie('st_key', '');
});
});
<!DOCTYPE html>
<html lang="jp">
<head>
<meta charset="UTF-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script src="script.js"></script>
</head>
<body>
<h1 id="msg">Hello JavaScrit</h1>
<div class="box">
<div class="type1"></div>
<div class="type2"></div>
<div class="type3"></div>
<div class="type4"></div>
<div class="type5"></div>
<div class="type6"></div>
<div class="type7"></div>
<div class="type8"></div>
<div class="type9"></div>
</div>
<p><button id="save_json">JSONのCookieを保存する</button></p>
<p><button id="delete_json">JSONのCookieを削除する</button></p>
</body>
</html>
Q. Cookieの保持期間が 1年後+9時間 になってしまう A. こまけぇこたぁいいんだよ!!
aryCookie = [];
for(i=0,j=4; i<j; i++){
var objCookie = {};
var cRed = "赤"+i,
cGrn = "緑"+i,
cBlu = "青"+i;
objCookie.red = cRed;
objCookie.green = cGrn;
objCookie.blue = cBlu;
aryCookie.push(objCookie);
}
console.log(JSON.stringify(aryCookie));
[{"red":"赤0","green":"緑0","blue":"青0"},{"red":"赤1","green":"緑1","blue":"青1"},{"red":"赤2","green":"緑2","blue":"青2"},{"red":"赤3","green":"緑3","blue":"青3"}]
Q. Cookieの保持期間が 1年後+9時間 になってしまう
A. expire.toGMTString();
で解決した
IEではGMTString 形式の日付でないとセッションクッキー状態になってしまうようだ https://developer.mozilla.org/ja/docs/Web/API/Document/cookie
変更前
{%22sType%22:%22type1%22%2C%22sRari%22:%22ssr%22%2C%22sSele%22:%222040244000%22%2C%22sRank%22:%22rank0%22}
{%22sType%22:%22type2%22%2C%22sRari%22:%22ssr%22%2C%22sSele%22:%222040243000%22%2C%22sRank%22:%22rank0%22}
{%22sType%22:%22type3%22%2C%22sRari%22:%22ssr%22%2C%22sSele%22:%222040237000%22%2C%22sRank%22:%22rank0%22}
変更後
%5b%7b%22id%22%3a%222040244000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type1%22%2c%22type%22%3a%22type1%22%7d%2c%7b%22id%22%3a%222040243000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type2%22%2c%22type%22%3a%22type2%22%7d%2c%7b%22id%22%3a%222040237000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type3%22%2c%22type%22%3a%22type3%22%7d%2c%7b%22id%22%3a%222040239000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type4%22%2c%22type%22%3a%22type4%22%7d%2c%7b%22id%22%3a%222040242000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type5%22%2c%22type%22%3a%22type5%22%7d%2c%7b%22id%22%3a%222040238000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type6%22%2c%22type%22%3a%22type6%22%7d%2c%7b%22id%22%3a%222040240000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type7%22%2c%22type%22%3a%22type1%22%7d%2c%7b%22id%22%3a%223040138000%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22ssr%22%2c%22target%22%3a%22type8%22%2c%22type%22%3a%22type2%22%7d%2c%7b%22id%22%3a%22120001_wa%22%2c%22rank%22%3a%22rank0%22%2c%22rarity%22%3a%22c1%22%2c%22target%22%3a%22type9%22%2c%22type%22%3a%22Djeeta%22%7d%2c%7b%22summon%22%3afalse%2c%22target%22%3a%22setting%22%2c%22text%22%3a%22%e3%81%84%e3%82%8d%e3%81%af%e3%81%ab%e3%81%bb%e3%81%b8%e3%81%a8%e3%81%a1%e3%82%8a%e3%81%ac%e3%82%8b%e3%82%92%e3%82%8f%e3%81%8b%e3%82%88%e3%81%9f%e3%82%8c%e3%81%9d%e3%81%a4%e3%81%ad%e3%81%aa%e3%82%89%e3%82%80%e3%81%86%e3%82%90%e3%81%ae%e3%81%8a%e3%81%8f%e3%82%84%e3%81%be%e3%81%91%e3%81%b5%e3%81%93%e3%81%88%e3%81%a6%e3%81%82%e3%81%95%e3%81%8d%e3%82%86%e3%82%81%e3%81%bf%e3%81%97%e3%82%91%e3%81%b2%e3%82%82%22%2c%22user%22%3a%221234567890%22%7d%5d
[{"id":"2040244000","rank":"rank0","rarity":"ssr","target":"type1","type":"type1"},{"id":"2040243000","rank":"rank0","rarity":"ssr","target":"type2","type":"type2"},{"id":"2040237000","rank":"rank0","rarity":"ssr","target":"type3","type":"type3"},{"id":"2040239000","rank":"rank0","rarity":"ssr","target":"type4","type":"type4"},{"id":"2040242000","rank":"rank0","rarity":"ssr","target":"type5","type":"type5"},{"id":"2040238000","rank":"rank0","rarity":"ssr","target":"type6","type":"type6"},{"id":"2040240000","rank":"rank0","rarity":"ssr","target":"type7","type":"type1"},{"id":"3040138000","rank":"rank0","rarity":"ssr","target":"type8","type":"type2"},{"id":"120001_wa","rank":"rank0","rarity":"c1","target":"type9","type":"Djeeta"},{"summon":false,"target":"setting","text":"いろはにほへとちりぬるをわかよたれそつねならむうゐのおくやまけふこえてあさきゆめみしゑひも","user":"1234567890"}]
注意点