【发布时间】:2017-10-29 00:14:21
【问题描述】:
我正在尝试创建一个计算以获取起始编号、结束编号和步数,以显示开始和结束之间的所有偶数按步值计数。
我的循环的逻辑似乎有问题,因为它不会停止并崩溃。
<!DOCTYPE html>
<html>
<body>
<h2>JFinding all even numbers</h2>
<p>Please input a starting number, ending number and step number:</p>
Starting Number: <input id="start">
Ending Number: <input id="end">
Step by Number: <input id="step">
<button type="button" onclick="myFunction()">Submit</button>
<p id="demo"></p>
<script>
function myFunction() {
var start, end, step, text;
var result = [];
// Get the value of the start number with start var
start = parseInt(document.getElementById("start").value);
// Get the value of the end number with end var
end = parseInt(document.getElementById("end").value);
// Get the value of the step number with step var
step = parseInt(document.getElementById("step").value);
console.log('start', start);
console.log('end', end);
console.log('step', step);
// If start, end, or step is Not a Number or step is not even or start is greater than end or step is greater than end or start and step are equal to end
if (isNaN(start) || isNaN(end) || isNaN(step) || step % 2 !== 0 || start > end || step > end || step === end || start === end) {
//display text for invalid input
text = "Input not valid";
//display text to html page
document.getElementById("demo").innerHTML = text;
//else create a loop to find even numbers
} else {
if(start % 2 === 0){
for(var i = start; i <= end; i += step){
result.push(i);
}
} else {
start += 1;
for(var i = start; i <= end; i += step){
result.push(i);
}
}
//sent the result to the html page
document.getElementById("demo").innerHTML = result;
}
console.log(result);
}
</script>
</body>
</html>
【问题讨论】:
-
sum永远不会超过start + step,因为sum = start + step;您可能希望将 sum 初始化为 = start,然后将该行更改为sum += step;
标签: javascript html forms loops