我正在编写一个 JS 代码来计算给定一些个人成绩的最终成绩并在 html 页面中输出结果,但是当我触发事件和函数时,它仅在我的 for 循环中循环一次,而不会到达代码的其余部分(我检查了使用打印语句),但我不明白导致无法访问其余代码的循环有什么问题。
HTML:
<!DOCTYPE html>
<html>
<head>
<title>Problem 2</title>
<script src="grades.js" type="text/javascript"></script>
</head>
<body>
<h1>Grade Calculator</h1>
<form id ="myForm">
<div id="assignments">
HW <input type="text" size="1"/> / <input type="text" size="1"/><br/>
HW <input type="text" size="1"/> / <input type="text" size="1"/><br/>
HW <input type="text" size="1"/> / <input type="text" size="1"/>
</div>
<div>
<input type="checkbox" id="curve"/> Curve +5?
</div>
<div id="resultsarea">
<p>
<!--add buttons here -->
<button type="button" id="comp">Compute</button>
<button type="button" id="clr">Clear</button>
</p>
<!-- add results here -->
</div>
</form>
</body>
</html>
JS:
window.onload = pageLoad;
function pageLoad()
{
var cbutton = document.getElementById("comp");
cbutton.onclick = compute;
}
function compute()
{
var list = document.getElementsByTagName("input");
var marks = 0;
var total = 0;
for (var i=1; i <= list.length; i++)
{
if(list[i].type == "text")
{
if (i%2 != 0)
marks += list[i].value;
else
total += list[i].value;
}
}
var result = Math.round(marks/total);
if (document.getElementById("curve").checked)
result += 5;
var out = document.createElement("div");
var t = document.createTextNode(result);
out.appendChild(t);
var display = document.getElementById("resultsarea");
display.append(out);
}