Добавить активный класс к текущему элементу с cookie - PullRequest
0 голосов
/ 24 октября 2018

Я пытаюсь заставить этот активный класс оставаться при перезагрузке страницы, для этого я создал Fiddle, нашел где-то в Stackoverflow код JS и мне не удалось заставить его работать.Я хочу добавить активный класс к родительскому и дочернему элементу.

<ul id="nav" class="navHolder">
<li><a href="#"><i class="fa fa-home"></i> Home</a></li>

<li class="subNav ">
    <a href=""><i class="fa fa-shopping-cart"></i> Shop</a>
 <ul>
    <li><a href="#">Men
        </a></li>
    <li><a href="#">Women</a></li>
    <li><a href="#">Kids</a></li>
 </ul>
  </li>
</ul>

Это JS из Stackoverflow:

    $( "li" ).click(function(e) {
    $("li").removeClass("active");
    $(e.target).parent("li").addClass("active");
    $(e.target).parent("li").parents("li").addClass("active");

    var x = 0;
    $("li").removeClass("setCookie");
    $(this).addClass("setCookie");
        $('#nav').children('li').each(function () {
        if ($(this).hasClass("setCookie")) {
            createCookie("setCookie", x, 2); 
        } 
        x = x+1;
    });    
   });

  $(document).ready(function() {
    $("li").removeClass("active");
    var x = 0;
    var setCookie = readCookie("setCookie");
    $('#nav').children('li').each(function () {
        if (setCookie==x) $(this).addClass("active");
        x = x+1;
    }); 
  });

  function createCookie(name, value, days) {
    var expires;
    if (days) {
        var date = new Date();
        date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
        expires = "; expires=" + date.toGMTString();
    } else {
        expires = "";
    }
    document.cookie = encodeURIComponent(name) + "=" + 
     encodeURIComponent(value) + expires + "; path=/";
  }

  function readCookie(name) {
    var nameEQ = encodeURIComponent(name) + "=";
    var ca = document.cookie.split(';');
    for (var i = 0; i < ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0) === ' ')
            c = c.substring(1, c.length);
        if (c.indexOf(nameEQ) === 0)
            return decodeURIComponent(c.substring(nameEQ.length, c.length));
    }
    return null;
  }

Есть идеи, как решить эту проблему? Fiddle

...