jquery を使用して Cookie を設定し、どの div が切り替えられたかを記憶し、ページが更新されたときにそれを切り替えたままにするにはどうすればよいですか?
私は多くの解決策を試しましたが、ほとんど解決しましたが、Cookie の設定と取得の際に行き詰まりました。
My HTML:
<a href="javascript:showonlyone('newboxes2');" >Login</a>
<a href="javascript:showonlyone('newboxes3');" >Register</a>
<div class="newboxes" id="newboxes1" style="display: block">
default text to be shown when no cookies are set
</div>
<div class="newboxes" id="newboxes2" style="display: none">
login form
</div>
<div class="newboxes" id="newboxes3" style="display: none">
register form
</div>
私のスクリプト:
/************jQuery Cookie**************/
;(function(g){g.cookie=function(h,b,a){if(1<arguments.length&&(!/Object/.test(Object.prototype.toString.call(b))||null===b||void 0===b)){a=g.extend({},a);
if(null===b||void 0===b)a.expires=-1;
if("number"===typeof a.expires){var d=a.expires,c=a.expires=new Date;
c.setDate(c.getDate()+d)}b=""+b;
return document.cookie=[encodeURIComponent(h),"=",a.raw?b:encodeURIComponent(b),a.expires?";
expires="+a.expires.toUTCString():"",a.path?";
path="+a.path:"",a.domain?";
domain="+a.domain:"",a.secure?";
secure":
""].join("")}for(var a=b||{},d=a.raw?function(a){return a}:decodeURIComponent,c=document.cookie.split("; "),e=0,f;f=c[e]&&c[e].split("=");
e++)if(d(f[0])===h)return d(f[1]||"");
return null}})(jQuery);
if ($.cookie('showDiv') == 'newboxes2'){
newboxes2.show();
}
if ($.cookie('showDiv') == 'newboxes3'){
newboxes3.show();
}
function showonlyone(thechosenone) {
$('.newboxes').each(function(index) {
if ($(this).attr("id") == thechosenone) {
$(this).show(200);
$.cookie('showDiv', thechosenone);
}
else {
$(this).hide(600);
}
});
}
Cookie コードが適切にフォーマットされていない場合は、http: //jsfiddle.net/CQFJ4/に実際の例がありますが、そのフィドルでは必要な処理が行われません。Cookie コードを借りただけです。
私が立ち往生している場所は、 $(this) を使用して各ループで Cookie を設定し、ページが更新されたときにその Cookie を呼び出す こと です。