Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 09.06.2022, 13:49
Профессор
Отправить личное сообщение для Сергей Ракипов Посмотреть профиль Найти все сообщения от Сергей Ракипов
 
Регистрация: 01.06.2010
Сообщений: 651

localStorage
Не могу правильно записать.

Вот есть переключатель что бы менял оформление с темного на светлое, ну и запоминал это. Я сделал переключатель вроде в локал записывает но не запоминает.

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

<head>
    <style>
        body {
            background-color: #fff;
            color: #000;
        }

        .temny {
            background-color: #000;
            color: #fff;
        }

        .blok {
            width: 320px;
            margin: 0 auto;
        }

        input[type="checkbox"] {
            -webkit-appearance: none;
            -moz-appearance: none;
            appearance: none;
            -webkit-tap-highlight-color: transparent;
            cursor: pointer;
        }

        input[type="checkbox"]:focus {
            outline: 0;
        }

        .toggle {
            height: 32px;
            width: 52px;
            border-radius: 16px;
            display: inline-block;
            position: relative;
            margin: 0;
            border: 2px solid #474755;
            background: linear-gradient(180deg, #2D2F39 0%, #1F2027 100%);
            transition: all .2s ease;
        }

        .toggle:after {
            content: '';
            position: absolute;
            top: 2px;
            left: 2px;
            width: 24px;
            height: 24px;
            border-radius: 50%;
            background: white;
            box-shadow: 0 1px 2px rgba(44, 44, 44, 0.2);
            transition: all 0.2s cubic-bezier(0.5, 0.1, 0.75, 1.35);
        }

        .toggle:checked {
            border-color: #654FEC;
        }

        .toggle:checked:after {
            transform: translatex(20px);
        }
    </style>
</head>

<body>
    <br><br>
    <div class="blok">
        <div class="tema_oformlenie">
            <input type="checkbox" class="toggle" checked>
        </div>
        <br><br>
        Таким образом, укрепление и развитие внутренней структуры говорит о возможностях дальнейших направлений
        развития. Внезапно, сторонники тоталитаризма в науке освещают чрезвычайно интересные особенности картины в
        целом, однако конкретные выводы, разумеется, представлены в исключительно положительном свете. Внезапно, активно
        развивающиеся страны третьего мира и по сей день остаются уделом либералов, которые жаждут быть превращены в
        посмешище, хотя само их существование приносит несомненную пользу обществу.
    </div>
    <script>
        window.onload = function () {
            if ( localStorage.getItem( "tema_st" ) !== null ) {
                let color = localStorage.getItem( "tema_st" );
                document.getElementsByTagName( "body" )[ 0 ].classList.add = color;
            }
        }

        document.querySelector(".toggle").onclick = function (){
		document.getElementsByTagName("body")[0].classList.add = "temny";
		localStorage.setItem("tema_st", "temny");
	}


        const tema = document.getElementsByTagName( "body" )[ 0 ];

        perek = () => {
            tema.classList.toggle( "temny" );
        }
        tema.addEventListener( "click", perek );
    </script>
</body>

</html>
Ответить с цитированием
  #2 (permalink)  
Старый 09.06.2022, 14:18
Профессор
Отправить личное сообщение для Nexus Посмотреть профиль Найти все сообщения от Nexus
 
Регистрация: 04.12.2012
Сообщений: 3,735

classList.add - метод, а не свойство.
https://developer.mozilla.org/ru/doc...%D1%80%D1% 8B
Ответить с цитированием
  #3 (permalink)  
Старый 09.06.2022, 16:11
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,075

смена темы оформления
Сергей Ракипов,

<!DOCTYPE html>
<html lang="en">
<head>
    <style>
        body {
            background-color: #fff;
            color: #000;
        }
        .temny {
            background-color: #000;
            color: #fff;
        }
        .blok {
            width: 320px;
            margin: 0 auto;
        }
        input[type="checkbox"] {
            -webkit-appearance: none;
            -moz-appearance: none;
            appearance: none;
            -webkit-tap-highlight-color: transparent;
            cursor: pointer;
        }
        input[type="checkbox"]:focus {
            outline: 0;
        }
        .toggle {
            height: 32px;
            width: 52px;
            border-radius: 16px;
            display: inline-block;
            position: relative;
            margin: 0;
            border: 2px solid #FFFFFF;
            background-image: linear-gradient(180deg, #2D2F39 0%, #1F2027 100%);
            transition: all .2s ease;
        }
        .toggle:after {
            content: '';
            position: absolute;
            top: 2px;
            left: 2px;
            width: 24px;
            height: 24px;
            border-radius: 50%;
            background-color: white;
            box-shadow: 0 1px 2px rgba(44, 44, 44, 0.2);
            transition: all 0.2s cubic-bezier(0.5, 0.1, 0.75, 1.35);
        }
        .toggle:checked:after{
          background-color:  #000000;

        }

        .toggle:checked {
            border-color: #000000;
            background-image: linear-gradient(180deg, #FFFFFF 0%, #DEDEDE 100%);
        }
        .toggle:checked:after {
            transform: translatex(20px);
        }
    </style>
</head>
<body>
    <br><br>
    <div class="blok">
        <div class="tema_oformlenie">
            <input type="checkbox" class="toggle" checked>
        </div>
        <br><br> Таким образом, укрепление и развитие внутренней структуры говорит о возможностях дальнейших направлений развития. Внезапно, сторонники тоталитаризма в науке освещают чрезвычайно интересные особенности картины в целом, однако конкретные
        выводы, разумеется, представлены в исключительно положительном свете. Внезапно, активно развивающиеся страны третьего мира и по сей день остаются уделом либералов, которые жаждут быть превращены в посмешище, хотя само их существование приносит
        несомненную пользу обществу.
    </div>
    <script>
        window.addEventListener("load", function() {
            let color = localStorage.getItem("tema_st");
            const body = document.body, toggle = document.querySelector(".toggle") ;
            if (color) {
            body.classList.add(color);
            toggle.checked = false;
            }
            toggle.addEventListener("click", function() {
                body.classList.toggle("temny");
                color = body.classList.contains("temny") ? "temny" : "";
                localStorage.setItem("tema_st", color)
            })
        })
    </script>
</body>
</html>
Ответить с цитированием
  #4 (permalink)  
Старый 10.06.2022, 08:11
Профессор
Отправить личное сообщение для Сергей Ракипов Посмотреть профиль Найти все сообщения от Сергей Ракипов
 
Регистрация: 01.06.2010
Сообщений: 651

Nexus,
Я пока плохо разбираюсь, но спасибо. И когда читаю вроде все понятно а когда дело доходит до практики я теряюсь
Ответить с цитированием
  #5 (permalink)  
Старый 10.06.2022, 08:11
Профессор
Отправить личное сообщение для Сергей Ракипов Посмотреть профиль Найти все сообщения от Сергей Ракипов
 
Регистрация: 01.06.2010
Сообщений: 651

рони,
Спасибо )))
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Можно ли использовать значение из localstorage в PHP smart-create Events/DOM/Window 12 07.11.2016 02:54
LocalStorage удаление данных neon_tmn Общие вопросы Javascript 8 21.10.2016 15:22
После добавления localstorage в backbone модель, POST запрос ничего не возвращает aphex Общие вопросы Javascript 0 03.12.2013 15:26
Обход элементов localStorage berserk10 Events/DOM/Window 8 11.08.2013 14:55
Не сохраняется localStorage после перезагрузки браузера Бобр Firefox/Mozilla 1 20.10.2011 20:31