Как скрыть div за 24 часа с cookie - PullRequest
0 голосов
/ 07 декабря 2018

Мне нужно скрыть это div в течение 24 часов.put это не работает.

Мне нужен простой код JavaScript, который позволит мне скрывать определенный элемент div при нажатии в течение предварительно определенного промежутка времени.
Чтобы быть немного более информативным, У меня есть окно предложений, которое появляется, когда загружается домашняя страница.Я хотел бы, чтобы при нажатии кнопки закрытия div он устанавливал cookie-файл, чтобы держать поле div закрытым в течение 24 часов (1 дня).
Проще говоря, когда нажата кнопка закрытия div, поле div скрыто в течение 24 часов.

Примечание. У меня есть код JavaScript, который позволяет кнопке закрытия закрыть окно, но он будет перезагружаться при каждом обновлении.
Ссылка нафайл проекта (Комментарий редактора: скачивать файлы с ненадежных веб-сайтов небезопасно, лучше подождать, пока автор отредактирует вопрос с помощью кода.)

Ответы [ 2 ]

0 голосов
/ 12 мая 2019

Спасибо всем за правильный код IS

$(document).ready(function() {

  // If the 'hide cookie is not set we show the message
  if (!readCookie('hide')) {
    $('#applink').show();
  }else {
    $('#applink').hide();
  }

  // Add the event that closes the popup and sets the cookie that tells us to
  // not show it again until one day has passed.
  $('#playstorclose').click(function() {
    $('#applink').hide();
    createCookie('hide', true, 1)
    return false;
  });

});

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

function readCookie(name) {
  var nameEQ = 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 c.substring(nameEQ.length,c.length);
  }
  return null;
}

function eraseCookie(name) {
  createCookie(name,"",-1);
}
<div class="playstorapp" id="applink" style="text-align: center;margin: auto">
        <a id="playstorclose" href="JavaScript:void(0)">X</a>
        <a class="applink" href="https://play.google.com/store/apps/details?id=com.aradev.net&rdid=com.aradev.net" target="_blank">
            Download
        </a>
    </div>
0 голосов
/ 07 декабря 2018

Как я заметил, #splashscreen по умолчанию установлено видимым.Вы можете либо скрыть его по умолчанию и показать его, только если файл cookie отсутствует .Или еще проще добавить else statement и скрыть его, если файл cookie присутствует.Пожалуйста, измените первый if statement вашего кода JS, как показано ниже.

// If the 'hide cookie is not set we show the message
  if (!readCookie('hide')) {
    $('#splashscreen').show();
  } else {
    $('#splashscreen').hide();
  }
...