【发布时间】:2022-01-13 10:20:34
【问题描述】:
var br = document.createElement("br");
function productCheck() {
var form = document.createElement("form");
var price = document.createElement("input");
price.setAttribute("type", "number");
price.setAttribute("id", "number1");
price.setAttribute("placeholder", "Product Price");
price.onchange = handleChange;
var qty = document.createElement("input");
qty.setAttribute("type", "number");
qty.setAttribute("id", "number2");
qty.setAttribute("placeholder", "quantity");
qty.onchange = handleChange;
var discount = document.createElement("input");
discount.setAttribute("type", "number");
discount.setAttribute("id", "number3");
discount.setAttribute("placeholder", "discount");
discount.onchange = handleChange;
var div = document.createElement("div");
div.setAttribute("id", "total");
form.appendChild(br.cloneNode());
div.onchange = handleChange;
form.appendChild(price);
// Inserting a line break
form.appendChild(br.cloneNode());
...
form.appendChild(qty);
...
form.appendChild(discount);
...
form.appendChild(div);
...
document.getElementsByTagName("body")[0]
.appendChild(form);
}
function handleChange() {
var p = document.getElementById("number1").value;
var q = document.getElementById("number2").value;
var d = document.getElementById("number3").value;
var total = parseFloat(p) * parseInt(q);
var discount_applied = parseFloat(total * d / 100);
var eff_price = parseFloat(total) - parseFloat(discount_applied);
if (!isNaN(eff_price))
return " ";
if (p > 0 && q > 0){
var eff = document.querySelector("#total");
eff.innerHTML = eff_price.toFixed(2);
}
}
添加更多字段创建了一个包含多个输入的表单。问题在于输出。我只得到 1 个输出。添加多个输入后,我只在第一次出现时得到输出。我如何解决每次出现的问题?我想要只使用 JS 和 HTML 的解决方案。此处不允许使用 jquery。
【问题讨论】:
标签: javascript html forms user-input