@SergOdinokiy

Как написать функцию смены фона и хранения выбранного фона в cookie?

Как написать функцию смены фона и хранения выбранного фона в cookie? Фоны находятся в массиве. Надо если в cookie пусто брать первый если есть то брать из cookie. А так же менять их если дойдет до конца массива начинать с первого фона. Всего будет одна кнопка <<сменить фон>> Как данное сделать?
const fon=["_bg1.jpeg","_bg2.jpeg","_bg3.jpeg","_bg4.jpeg","_bg5.jpeg","_bg6.jpeg"];
    function getFon(name) {
        let matches = document.cookie.match(new RegExp(
            "(?:^|; )" + name.replace(/([\.$?*|{}\(\)\[\]\\\/\+^])/g, '\\$1') + "=([^;]*)"
        ));
        return matches ? decodeURIComponent(matches[1]) : undefined;
    }
    function setFon() {
    document.cookie = "gameFon=0";
    document.getElementsByClassName("app")[0].style.background="url(????)";
    console.info(getFon("gameFon"));
    }
  • Вопрос задан
  • 98 просмотров
Решения вопроса 1
yarkov
@yarkov Куратор тега JavaScript
Помог ответ? Отметь решением.
Вариант с LocalStorage:
const backgrounds = ["_bg1.jpeg","_bg2.jpeg","_bg3.jpeg","_bg4.jpeg","_bg5.jpeg","_bg6.jpeg"];

function getFon(name) {
	return localStorage.getItem(name);
}

function setFon() {
	let background = getFon('gameFon');

  if (!background) {
  	localStorage.setItem('gameFon', backgrounds[0]);
  	background = backgrounds[0];
  }

  document.getElementsByClassName('app')[0].style.background = `url(${background})`;
  console.info(background);
}

setFon();
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы
КРАФТТЕК Санкт-Петербург
от 60 000 до 80 000 ₽
Brightdata Тель-Авив
от 5 500 до 6 500 $
Rocket Брянск
от 60 000 до 100 000 ₽
21 мая 2024, в 14:04
90000 руб./за проект
21 мая 2024, в 14:00
500 руб./за проект
21 мая 2024, в 13:51
19000 руб./за проект