Задать вопрос
@xzekov

Включение и выключение функцыи JS?

нужно сделать включение и выключение функцыи на одну кнопку
<span id="move-me-3" style="position: absolute; border: 1px dashed black;">Подвижный Текст<br>
</span>

<script>
var rho = 150;
var phi = -5;
var phiOffset = Math. PI / 180 * 1.5;
var xOffset = 900; 
var yOffset = 350; 
var toggle = true;




function moveByCircle(){
                

document.getElementById('move-me-3').style.right = rho * Math.cos(phi) + xOffset + 'px'; 
document.getElementById('move-me-3').style.top = rho * Math.sin(phi) + yOffset + 'px';
phi += phiOffset;
}
setInterval(moveByCircle, 0);

function ByCircle(){
clearInterval(moveByCircle , stop);
}

</script>
<input type="button" value="ЗДЕСЬ" onClick="ByCircle()"  >
  • Вопрос задан
  • 157 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
sergiks
@sergiks Куратор тега JavaScript
♬♬
Лучше вместо setInterval() использовать requestAnimationFrame()
Там принцип: отрисовали кадр – запросили отрисовку следующего. Пошаговая передача эстафеты.

Завести переменную-флаг, которая будет true или false. Разрешать или запрещать анимацию.

На каждом шаге смотреть на эту переменную: и делать следующий requestAnimationFrame() только если переменная true.

Кнопка будет менять состояние этой переменной. И, при переключении из false в true, запускать отрисовку.

Ещё оптимизация: не нужно в каждом кадре искать элементы, достаточно это сделать один раз.

Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
delphinpro
@delphinpro Куратор тега JavaScript
frontend developer
При условии, что у вас в принципе правильно работает функция moveByCycle, делаем следующее:

Пишем две функции

let t; // Дескриптор счетчика setInterval

function startCycle() {
 t = setInterval(moveByCircle, 0);
}

function stopCycle() {
  clearInterval(t);
}


Функцию ByCycle выкидываем нахер, ибо непонятно, что она делает.

Кнопку переписываем

<button onclick="toggleCycle">ВКЛ/ВЫКЛ<button>

И пишем последнюю функцию

function toggleCycle() {
  if (t) {
    stopCycle();
  } else {
    startCycle();
  }
}
Ответ написан
Ваш ответ на вопрос

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

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