我正在尝试处理表单。目前,该按钮已被禁用。但是当您单击复选框时,应该启用该按钮,如果您没有单击复选框,则再次禁用该按钮。当我点击一个复选框时,我无法启用该按钮。我的循环可能有问题。循环在函数checkAge中。任何解决方案?
Javascript
function checkAge(e){
var theTarget = e.target ? e.target : e.srcElement;
alert(theTarget.id);
var form = document.getElementById("form");
if (document.getElementById("content")) {
form.removeChild(document.getElementById("content"));
}
if(theTarget.id == "fourteen"){
var newDiv = document.createElement("div");
newDiv.setAttribute("id", "content");
var br = document.createElement("br");
newDiv.appendChild(br);
var br = document.createElement("br");
newDiv.appendChild(br);
newDiv.appendChild(document.createTextNode("Vilka seriefigurer träffade du?"));
var br = document.createElement("br");
newDiv.appendChild(br);
var musse = document.createElement('input');
musse.setAttribute("type", "checkbox");
musse.setAttribute("name", "musse");
musse.setAttribute("value", "musse");
musse.setAttribute("id", "musse");
newDiv.appendChild(musse);
newDiv.appendChild(document.createTextNode("Musse"));
var br = document.createElement("br");
newDiv.appendChild(br);
var adi = document.createElement('input');
adi.setAttribute("type", "checkbox");
adi.setAttribute("name", "adi");
adi.setAttribute("value", "adi");
adi.setAttribute("id", "adi");
newDiv.appendChild(adi);
newDiv.appendChild(document.createTextNode("Ådi"));
var br = document.createElement("br");
newDiv.appendChild(br);
var bamse = document.createElement('input');
bamse.setAttribute("type", "checkbox");
bamse.setAttribute("name", "bamse");
bamse.setAttribute("value", "bamse");
bamse.setAttribute("id", "bamse");
newDiv.appendChild(bamse);
newDiv.appendChild(document.createTextNode("Bamse"));
var br = document.createElement("br");
newDiv.appendChild(br);
var input = document.createElement("input");
input.setAttribute("type", "submit");
input.setAttribute("name", "submit");
input.setAttribute("id", "submit");
input.setAttribute("value", "Skicka");
newDiv.appendChild(input);
form.appendChild(newDiv);
var inputs = document.getElementsByTagName("input");
for(i=0; i<inputs.length; i++){
input.disabled = true;
if(inputs[i].type == "checkbox" && inputs[i].checked){
input.disabled = false;
}
else{
input.disabled = true;
}
}
}
答案 0 :(得分:2)
创建复选框时,不会将任何事件附加到它们。只有在创建表单的checkAge部分时才会发生禁用输入的循环,并且永远不会再次执行。如果您将复选框附加偶数,那么它应该可以解决您的问题。
此外,checkAge函数会将复选框输入添加到文档中,但您永远不会更新inputs
数组以包含复选框。
您可能需要考虑最初将所有HTML元素添加到页面中,并使用display:none / display:block来隐藏/显示元素。