javascript - 如何获取多个输入字段的 ID 并将它们汇总在一个跨度中
问题描述
我有以下
<input type="text" class="form-control" name="total1" id="total1">
<input type="text" class="form-control" name="total1" id="total2">
我已经使用 javascript 获得了这两个值。
但我想在下面的跨度或 P 标签中显示结果
<span id="sum">0</span>
我尝试了以下...但我希望它是自动的...意味着一旦输入字段存在,总计也应该出现
<script type="text/javascript" language="javascript" charset="utf-8">
function output(){
var value1 = document.getElementById('value1').value;
var value2 = document.getElementById('value2').value;
document.getElementById('result').innerHTML = parseInt(value1) + parseInt(value2);
}
function updateTextInput(val) {
document.getElementById('value2').value=val;
}
</script>
解决方案
用一行 Javascript 计算。
function calc() {
document.querySelector('#sum').innerHTML = [...document.querySelectorAll('input')].reduce((acc, input) => acc + Number(input.value), 0);
}
<input type="text" class="form-control" name="total1" id="total1" onchange="calc()">
<input type="text" class="form-control" name="total1" id="total2" onchange="calc()">
<p id="sum"></p>
推荐阅读
- plsql - ORA-19280: XQuery 动态类型不匹配: 预期原子值 - 得到节点
- list - Tcl/Tk:从一列数据创建列表时如何忽略换行符?
- sql - SQL 增量记录数
- c - 在没有 printf 的情况下限制 c 中的浮点精度
- sql - Oracle SQL 中按时间段累积的第 90 个百分位值
- angular - 本地 Angular 构建成功,但 Gitlab 运行器 Angular 构建失败
- node.js - ECS Fargate Node.js child_process NoCredentialProviders:链中没有有效的提供者。已弃用
- java - Jnativehook Mouse Listener 问题(Java)
- regex - 使用 Python 正则表达式查找和编辑文本文件的内容
- python - Python + Pandas + 数据可视化:如何获取每行的百分比并可视化分类数据?