Я успешно закодировал следующее поведение:
- Три деления скрыты / показаны с помощью .toggle ();
- Когда пользователь использует .toggle ();он также устанавливает cookie, запоминая состояние переключения
Вот jQuery приведенного выше кода, который работает с комментариями:
<script>
$(document).ready(function () {
// If user clicks the toggle it hides/shows the divs
$(" .togglediv ").click(function () {
var closed = $(" .siemaholder, .c_l_off, .c_r_off ").is(":hidden");
if (closed)
$(" .siemaholder, .c_l_off, .c_r_off ").show();
else
$(" .siemaholder, .c_l_off, .c_r_off ").hide();
// If user uses the toggle it sets a cookie to remember the toggle state
setCookie("open", closed, 365);
});
var openToggle = getCookie("open");
if (openToggle=="true") {
$(" .siemaholder, .c_l_off, .c_r_off ").show();
}
else {
$(" .siemaholder, .c_l_off, .c_r_off ").hide();
}
});
function setCookie(c_name, value, exdays) {
var exdate = new Date();
exdate.setDate(exdate.getDate() + exdays);
var c_value = escape(value) + ((exdays == null) ? "" : "; expires=" + exdate.toUTCString());
document.cookie = c_name + "=" + c_value;
}
function getCookie(c_name) {
var i, x, y, ARRcookies = document.cookie.split(";");
for (i = 0; i < ARRcookies.length; i++) {
x = ARRcookies[i].substr(0, ARRcookies[i].indexOf("="));
y = ARRcookies[i].substr(ARRcookies[i].indexOf("=") + 1);
x = x.replace(/^\s+|\s+$/g, "");
if (x == c_name) {
return unescape(y);
}
}
}
</script>
Проблема у меня заключается в том, что когда нетcookie еще существует (когда пользователь заходит на страницу в первый раз и еще не сгенерировал куки), div по умолчанию скрыт .Я не хочу этого - я хочу, чтобы они по умолчанию показывали .
Я намерен показать их по умолчанию, пока не будет установлен cookie с помощью .toggle ();что я упоминал ранее.Так что, когда пользователь впервые заходит на страницу, контент отображается и затем может быть «скрыт» пользователем вручную (что запоминается с этого момента).
Может ли кто-нибудь мне помочь?
До сих пор я пытался использовать $(" .siemaholder, .c_l_off, .c_r_off ").show();
в начале скрипта, так что по умолчанию div будут отображаться, пока не будут задействованы куки.Это не сработало.