Как отключить повторное появление окна при помощи sessionStorage?

Подскажите, пожалуйста, как добавить ключ в sessionStorage по клику и чтобы при обновлении страницы при наличии этого ключа добавлялся класс display: none

Я написал пример, но он отрабатывает не до конца верно.
Заранее благодарю!

<!DOCTYPE html>
<html lang="en">

  <head>
    <meta charset="UTF-8">
    <title>Document</title>
  </head>

  <body>
    <section>
      <div class="object">
        <h2>Object</h2>
        <bottom class="tap">Tap</bottom>
      </div>
    </section>
  </body>

</html>


section {
  height: 100vh;
  background: #ccc;
  display: flex;
  align-items: center;
  justify-content: center;
}
div {
  padding: 1rem 3rem;
  background: #999;
}
bottom {
  display: block;
  padding: 1rem;
  background: #666;
  cursor: pointer;
}
.object.none {
  display: none;
}


let object = document.querySelector('.object');
let tap = document.querySelector('.tap');

function addSessionKey() {
	sessionStorage.setItem('hide', true);
  if (sessionStorage.getItem('hide') === true) {
  	object.classList.add('none');
	}
}

function hideObject() {
	object.classList.add('none');
}

tap.addEventListener('click', addSessionKey);
tap.addEventListener('click', hideObject);
  • Вопрос задан
  • 59 просмотров
Решения вопроса 1
MrDecoy
@MrDecoy Куратор тега JavaScript
Верставший фронтендер
А что хранит sessionStorage? Какой тип данных?
Строку.
Соответственно
sessionStorage.getItem('hide') === true // всегда false
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 06:06
1500 руб./в час
22 нояб. 2024, в 06:04
1 руб./за проект
22 нояб. 2024, в 03:54
1500 руб./за проект