Почему моя функция изменения цвета фона работает (оповещение работает), но не меняет цвет? - PullRequest
0 голосов
/ 11 октября 2018

В настоящее время изучаю Javascript, полный новичок.Попытка написать функцию, которая при нажатии кнопки переключает цвет фона элемента <body> с белого на фиолетовый и наоборот.

Предупреждение работает, поэтому функция запускается, ноцвет никогда не меняется.

Совершенно не знаю, что происходит ...

Заранее спасибо.

HTML:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
  <title>My Title</title>

</head>
<body>>
  <button>Click me!</button>

  <h1>I am an h1!</h1>
    <p id="first" class="special">Hello</p>
    <p class="special">Goodbye</p>
    <p>Hi Again</p>
  <p id="last">Goodbye Again</p>


  <!-- SCRIPS -->
  <script type="text/javascript" src="exercises.js"></script>
</body>
</html>

JavaScript:

var color_button = document.querySelector("button");
var is_purple = false;

color_button.addEventListener("click", function() {
    alert("clicked");
    if (is_purple = false) {
        document.querySelector("body").style.backgroundColor = "purple";
        is_purple = true;
    }
    else {
        document.querySelector("body").style.backgroundColor = "white";
        is_purple = false;
    }
});

1 Ответ

0 голосов
/ 11 октября 2018

Ваша проблема в том, что вы используете одинаковые равенства в компараторе.Единое равенство предназначено для присвоения значения переменной, а не для сравнения.

color_button.addEventListener("click", function() {
    alert("clicked");
//what you had
//    if (is_purple = false) {
//what it should be
      if (is_purple === false) {
        document.querySelector("body").style.backgroundColor = "purple";
        is_purple = true;
    }
    else {
        document.querySelector("body").style.backgroundColor = "white";
        is_purple = false;
    }
});
...