@holllop

Хочу сделать что при нажатии кнопка постепенно становится зеленой, но не могу понять, что я делаю не так?

вот моё решение
<button class="send" id="submit_button" onclick="fillButton()">Записать</button>

function fillButton() {
  var button = document.getElementById('submit_button');
  var color = 'green';
  var animationDuration = 2000; // Длительность анимации в миллисекундах

  var currentWidth = 0;
  var targetWidth = button.offsetWidth;

  var intervalId = setInterval(function() {
    if (currentWidth >= targetWidth) {
      clearInterval(intervalId);
      return;
    }

    currentWidth += 1;
    button.style.background = linear-gradient(to right, ${color} ${currentWidth}px, transparent ${currentWidth}px);
  }, animationDuration / targetWidth);
}

но что-то не так с градиентом, а что не могу понять.
  • Вопрос задан
  • 108 просмотров
Решения вопроса 1
Mike_Ro
@Mike_Ro Куратор тега JavaScript
Python, JS, WordPress, SEO, Bots, Adversting
Заменить:
button.style.background = linear-gradient(to right, ${color} ${currentWidth}px, transparent ${currentWidth}px);

На:
button.style.background = `linear-gradient(to right, ${color} ${currentWidth}px, transparent ${currentWidth}px)`;

Если бы Вы использовали современную IDE, например WebStorm (PhpStrom итп), то она сразу бы подсказала, где у Вас проблема:
651ea7052f61d672134203.png
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы