我正在尝试让用户输入添加到列表中的项目,然后找到列表中所有项目的总和。当然,这仅适用于数字,并且我会有说明提示用户仅输入数字,但是如何从用户输入的列表中获得项目的总和?
我当前的代码仅将用户输入的文本输入文本框,然后将这些项放入列表中。
<!DOCTYPE html>
<html>
<head></head>
<body>
<input type='text' id='input' />
<input type='button' value='add to list' id='add' />
<ul id='list'>
<li> <b>Topics</b></li>
</ul>
<script type="text/javascript">
document.getElementById("add").onclick = function() {
var text = document.getElementById("input").value;
var li = document.createElement("li");
li.innerText = text;
document.getElementById("list").appendChild(li);
}
</script>
</body>
</html>
答案 0 :(得分:0)
将其添加到名为sum
的变量中,然后使用.innerHTML
在页面上显示总和。
由于输入是字符串,请使用parseInt()
将其转换为数字,以便在将其加到求和时,它实际上是相加而不仅仅是将项目加到和的末尾。
下面的代码段有效。
var sum = 0;
document.getElementById("add").onclick = function() {
var text = document.getElementById("input").value;
var li = document.createElement("li");
li.innerText = text;
sum += parseInt(text);
document.getElementById("list").appendChild(li);
document.getElementById("sum").innerHTML = sum;
}
<!DOCTYPE html>
<html>
<head></head>
<body>
<input type='text' id='input' />
<input type='button' value='add to list' id='add' />
<ul id='list'>
<li> <b>Topics</b></li>
</ul>
<h3 id="sum">0</h3>
</body>
</html>
答案 1 :(得分:0)
您可以使用dataset
属性保留当前的总和,并为每个新的li
更新该属性。
<ul id='list' data-total="0">...</ul>
list.dataset.total = Number(list.dataset.total) + Number(text);
let list = document.getElementById("list");
let sum = document.getElementById("sum");
document.getElementById("add").onclick = function() {
let text = document.getElementById("input").value;
let li = document.createElement("li");
li.innerText = text;
list.appendChild(li);
list.dataset.total = Number(list.dataset.total) + Number(text);
sum.textContent = list.dataset.total;
}
<input type='text' id='input' />
<input type='button' value='add to list' id='add' />
<ul id='list' data-total="0">
<li><b>Topics (<span id='sum'></span>)</b></li>
</ul>