Javascript - 对于每个名称集ID等于Name [i]并验证

时间:2012-11-28 21:21:49

标签: javascript validation

好的我已经创建了一张发票,根据发票项目的数量,它会在每个项目旁边生成一个复选框以供审批。每个复选框的名称都为invoiceApproval

到目前为止,我的脚本会计算出有多少输入的名称为invoiceApproval,然后为ID = invoiceApproval[i]

的每个输入分配一个ID

这完全正常,但现在当我使用JavaScript Form Validation : quick and easy! in HTML Forms为每个ID分配frmvalidator.addValidation时(每个ID的数量等于有多少个复选框的名称为invoiceApproval)它仅验证ID为invoiceApproval0的第一个框。

为什么我的'for each'只适用于第一个实例?我在这做错了什么:

<script type="text/javascript"> 
    var frmvalidator  = new Validator("forminvoice"); 

    var inva = document.getElementsByName("invoiceApproval");
    for (var i = 0; i < inva.length;i++) {
        var inc = "invoiceApproval"+[i];
        inva[i].setAttribute("id",inc); 
    }


    var inva = document.getElementsByName("invoiceApproval");
    for (var i = 0; i < inva.length;i++) {
        var inc = "invoiceApproval"+[i];
        frmvalidator.addValidation(inc,"shouldselchk=x","You must check off each item on the right hand side of the invoice before you can submit approval.");
    }
</script>

生成复选框的PHP循环是:

while($row = mysql_fetch_array($result))
{
    echo "<input type='checkbox'  value='x' name ='invoiceApproval' > Approve";  
}

1 个答案:

答案 0 :(得分:0)

图书馆的代码正在使用

var itemobj = this.formobj[itemname];

检索表单项。后来它确实

if (itemobj.length && isNaN(itemobj.selectedIndex))
{
    itemobj = itemobj[0];
}

这意味着如果有多个具有相同名称的项目,它将始终选择第一个项目。为表单字段引用取名称是一种不好的做法

唯一的解决方案(如果你想使用这个库,但我会远离它,它写的很糟糕)是让你的名字不一样。

旁注

该行

var inc = "invoiceApproval"+[i];

创建一个包含单个值的数组,然后在其上调用toString,而toString(幸运的是)会返回一个值数组作为值本身。摆脱那些括号,应该是

var inc = "invoiceApproval"+i;