【发布时间】:2017-05-11 08:18:08
【问题描述】:
基本上,我正在尝试创建一个有 2 个按钮的网页;一种会导致屏幕随机闪烁,另一种会导致屏幕缓慢改变颜色。我希望能够在这两者之间切换(如果你按下第一个按钮,它开始闪烁,然后如果你按下第二个按钮,它会慢慢改变,没有任何取消按钮)。
每个按钮都调用一个函数,该函数将另一个函数的“运行”变量设置为 false,并将它自己的“运行”变量设置为 true。然后它调用一个递归函数(递归,它只是一遍又一遍地调用自己)。这些递归函数仅在其“运行”变量为真时执行其代码。
如果您运行 sn-p,您会看到程序非常不一致(您可能需要使用它一段时间才能看到问题,因为它有时似乎可以工作)。有时它拒绝更改功能,有时这两个功能似乎都处于活动状态并且它们都尝试执行(看起来好像它们正在为控制而战)。我不明白这是怎么发生的,因为我相信,任何时候只有一个“运行”变量可以是真的。
var runningDisco = false;
var runningColours = false;
function startColours() {
if (runningDisco == true); //Is disco running?
{
runningDisco = false; //If yes, stop it
}
runningColours = true; //Indicate we are running
window.setTimeout(Colours, 100, 0); //Run
}
function startDisco() {
if (runningColours == true); {
runningColours = false;
}
runningDisco = true;
window.setTimeout(Disco, 100);
}
function Disco() {
if (runningDisco == true); {
hex = "#";
for (discoCount = 0; discoCount < 6; discoCount++) {
hex = hex.concat((Math.floor(Math.random() * 17)).toString(16));
}
document.body.style.background = hex;
window.setTimeout(Disco, 10);
}
}
function Colours(colourCount) {
if (runningColours == true); {
if (colourCount > 359) {
colourCount -= 359;
}
document.body.style.background = "hsl(" + colourCount + ", 50%, 50%)";
window.setTimeout(Colours, 10, colourCount + 1);
}
}
input {
font-family: 'Roboto', sans-serif;
text-align: center;
background-color: #dd1021;
border: none;
color: white;
padding: 16px 32px;
text-decoration: none;
margin: 4px 2px;
cursor: pointer;
}
<link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet">
<input id="clickMe" type="button" value="Start Disco" onclick="startDisco();" />
<input id="clickMe" type="button" value="Start Colours" onclick="startColours();" />
【问题讨论】:
-
我不明白你的标题。这是一个问题还是什么?请让标题更清楚
-
用
setTimeout运行相同的函数并不是真正的递归。 -
是的,这就是为什么我说 递归,因为它只是一遍又一遍地调用自己。不太确定这样的东西的正确名称是什么
-
也许recurring这个词更合适。
标签: javascript