@flexpc

Почему не работает смена темы на сайте?

У меня есть вот такой код html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="\bootstrap5\css\bootstrap.css">
    <link rel="stylesheet" href="css\main.css" id="theme1">
    <link rel="shortcut icon" href="\resource\img\2379396.svg" type="image/x-icon">
    <link rel="stylesheet" href="css/fontello.css">
    <title>Закрепи Знания</title>
</head>
<body>
    <button id="theme" type="button" class="btn btn-primary active" data-toggle="button" autocomplete="off" aria-pressed="true">СМЕНИТЬ ТЕМУ</button>
    <script src="\bootstrap5\js\bootstrap.bundle.min.js"></script>
    <script src="\js\main.js"></script>
    <script src="\main.js"></script>
</body>
</html>

И вот такой js:

let switchMode = document.getElementById("theme");

switchMode.onclick = function() {
    let theme = document.getElementById("theme1");

    if (theme.getAttribute("href" == "css\main.css"))
    {
        theme.href = "css\main_dark.css";
        console.log(1);
    }
    else
    {
        theme.href = "css\main.css";
        console.log(0);
    }
}

Этот код должен менять тему на сайте, путем смены css, но почему-то этого не делает. Более того в консоль всегда выводится 0. В чем ошибка?
  • Вопрос задан
  • 154 просмотра
Пригласить эксперта
Ответы на вопрос 3
@joseffie
Front-end developer
У вас ошибка в строке if (theme.getAttribute("href" == "css\main.css")). Вы некорректно разместили условие, указав его в аргументах метода getAttribute.

Попробуйте заменить это на if (theme.getAttribute("href") == "css\main.css")
Ответ написан
irtek
@irtek
Wordpress-addicted
Первый момент, в пути к файлу нужно использовать обратный слеш "/", соответственно в html нужно обновить адрес в строке
<link rel="stylesheet" href="css/main.css" id="theme1">


Второй момент, атрибут правильнее присваивать через метод setAttribute нежели напрямую присваивать через "="

let switchMode = document.getElementById("theme");

switchMode.onclick = function() {
    let theme = document.getElementById("theme1");

    if (theme.getAttribute("href") === "css/main.css") {
        theme.setAttribute("href", "css/main_dark.css");
        console.log(1);
    } else {
        theme.setAttribute("href", "css/main.css");
        console.log(0);
    }
}
Ответ написан
@wakenbyWork
Необходимо поменять \ на /
<link rel="stylesheet" href="css/main.css" id="theme1">


const switchMode = document.querySelector("#theme");
const theme = document.querySelector("#theme1")

switchMode.addEventListener('click', () => {
  theme.href === 'css/main.css'
    ? theme.href = 'css/main_dark.css'
    : theme.href = 'css/main.css'
})
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы