增加值直到限制然后减少循环

increase value until limit then decrease loop

本文关键字:循环 然后 增加值      更新时间:2023-09-26

我尝试将变量valuem的值从 0 增加到 10,如果 valuem 的值为 10,它应该减小直到值为 0,然后再次增加到 10,依此类推。

例如:0 1 2 3 4 5

6 7 8 9 10 9 8 7 6 5 4 3 2 1 0 1 2 ...

简单、最有效的方法是什么?

var valuem = 0;
$('#number').text(valuem);
function count() {
    valuem++;
    $('#number').text(valuem);
    if (valuem == 10) {
        valuem--;
        $('#number').text(valuem);
    }
}
setInterval(count, 1000);

这样:

var valuem = 0, dir = 1;
$('#number').text(valuem);
function count() {
  valuem += dir;
  $('#number').text(valuem);
  if (valuem < 1) dir = 1;
  if (valuem > 9) dir = -1;
}
setInterval(count, 1000);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="number"></div>

您必须将计数方向存储为当前数字之外的状态的一部分,以便知道当valuem介于 1 和 9 之间时要计数的方向。

我想可以通过仅使用带有偏移量的余数来简化它。这样,整个计算在一行中完成,没有任何 if 语句。

var n = 0;
setInterval(function() {
  number.innerHTML = 10 - Math.abs(n++ % 20 - 10);
}, 500);
<h1 id="number"></h1>