Страница 1 из 1

Tabs и cookie

СообщениеДобавлено: 07 июл 2011, 23:04
marion
Здравствуйте. Очень нужна чья-нибудь помощь :)
Поставил себе на сайт Tabs. У меня в "табсе" на сайте три вкладки и надо что бы запоминалась вкладка на какой последний раз был пользователь.
Понимаю что надо сделать это с помощью куки.
Подключил куки jquery.cookie.js, взятые с официального сайта:
Код: выделить все
jQuery.cookie = function(name, value, options) {
    if (typeof value != 'undefined') { // name and value given, set cookie
        options = options || {};
        if (value === null) {
            value = '';
            options.expires = -1;
        }
        var expires = '';
        if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {
            var date;
            if (typeof options.expires == 'number') {
                date = new Date();
                date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
            } else {
                date = options.expires;
            }
            expires = '; expires=' + date.toUTCString(); // use expires attribute, max-age is not supported by IE
        }
        // CAUTION: Needed to parenthesize options.path and options.domain
        // in the following expressions, otherwise they evaluate to undefined
        // in the packed version for some reason...
        var path = options.path ? '; path=' + (options.path) : '';
        var domain = options.domain ? '; domain=' + (options.domain) : '';
        var secure = options.secure ? '; secure' : '';
        document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');
    } else { // only name given, get cookie
        var cookieValue = null;
        if (document.cookie && document.cookie != '') {
            var cookies = document.cookie.split(';');
            for (var i = 0; i < cookies.length; i++) {
                var cookie = jQuery.trim(cookies[i]);
                // Does this cookie string begin with the name we want?
                if (cookie.substring(0, name.length + 1) == (name + '=')) {
                    cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                    break;
                }
            }
        }
        return cookieValue;
    }
};

Пробовал поставить js код от Tabs (Cookie persistence) с официального сайта:
Код: выделить все
$(document).ready(function() {
$(function() {
      $( "#tabs" ).tabs({
         cookie: {
            // store cookie for a day, without, it would be a session cookie
            expires: 1
         }
      });
   });
});

При таком коде у меня идет отображение табса только в виде html.

Еще на этом сайте видел тему по этому поводу. Вот ссылька тык<
Тут я то же подключал jquery.cookie.js. Напишу что у меня вообще подключено(мб тут ошибка)
Код: выделить все
<link type="text/css" href="css/jquery-ui-1.8.14.custom.css" rel="stylesheet" />
<script src="/js/jquery.cookie.js" type="text/javascript" charset="utf-8"></script>   
<script type="text/javascript" src="js/jquery-1.5.1.min.js"></script>
<script type="text/javascript" src="js/jquery-ui-1.8.14.custom.min.js"></script>
<script type="text/javascript" src="js/allscripts.js"></script>


В файле allscripts.js у я вставил такой код как было написано в теме выше:
Код: выделить все
$(document).ready(function() {



$(function(){

  $("#tabs").tabs({
    cookie: { expires: 7, name: "startTab" }
  });
  $("#getCookie").click(function(){
    var cook = $("#tabs").tabs("option", "cookie");
    alert("name: " + cook.name +
            "\nexpires: " + cook.expires);
  });
});
});


При таком коде у меня опять же идет отображение табса только в виде html.

Старался изложить все моменты, что бы было понятнее. Скажу что сам новичек, поэтому хотелось бы что бы ответы были более понятные для новичков :)
Надеюсь на помощь от профессионалов этого дела. Спасибо!

Re: Tabs и cookie

СообщениеДобавлено: 08 июл 2011, 10:17
zandroid
У вас плагин cookie подключен до самой библиотеки, а надо в первую очередь саму библиотеку jQuery подключать, а после неё уже все остальные плагины и UI.

Re: Tabs и cookie

СообщениеДобавлено: 08 июл 2011, 13:35
marion
Куки поставил в самое начало. Пробовал ставить второй код, а именно вот этот
Код: выделить все
$(document).ready(function() {



$(function(){

  $("#tabs").tabs({
    cookie: { expires: 7, name: "startTab" }
  });
  $("#getCookie").click(function(){
    var cook = $("#tabs").tabs("option", "cookie");
    alert("name: " + cook.name +
            "\nexpires: " + cook.expires);
  });
});
});

Но перейти по разным в кладкам tabsa нельзя. Вчем проблема назнаю...

Re: Tabs и cookie

СообщениеДобавлено: 08 июл 2011, 14:14
zandroid
Я писал про подключение плагина:
Код: выделить все
<link type="text/css" href="css/jquery-ui-1.8.14.custom.css" rel="stylesheet" />
<script src="/js/jquery.cookie.js" type="text/javascript" charset="utf-8"></script>   
<script type="text/javascript" src="js/jquery-1.5.1.min.js"></script>
<script type="text/javascript" src="js/jquery-ui-1.8.14.custom.min.js"></script>
<script type="text/javascript" src="js/allscripts.js"></script>

Re: Tabs и cookie

СообщениеДобавлено: 08 июл 2011, 15:34
marion
zandroid Спасибо большое! Все заработало =)
Я сначала прочитал и подумал что надо наоборот в самое начало поставить, а оказывается в самый конец. Невнимательный совсем я. Спасибо еще раз большое!