0

我有大约 20 个复选框。当用户选择这些然后使用备用提交按钮时,我需要更改所选输入的名称/值对的名称。

为什么这个函数只改变每个其他选定输入的名称?

function sub_d()
{

    for (i = 0; i < document.checks.OGname.length; i++) //for all check boxes
    {
        if (document.checks.OGname[i].checked == true)
        {
            document.checks.OGname[i].name="newname"; //change name of input 

        }

    }

    document.checks.submit();
}

输出:

newname
    '105' 
OGname
    '106' 
newname
    '107' 
OGname
    '108' 
newname
    '109' 
OGname
    '110' 
4

3 回答 3

1

通过重命名列表的第一个元素,您将列表的长度减少了一个并删除了第一个元素。下一次通过循环之前的第二个元素现在是第一个,第二个是旧的第三个。

我不是 javascript 专家,但类似的东西可能会起作用。

function sub_d()
{
  i=0;
  while (document.checks.OGname.length > i)
  {
    if (document.checks.OGname[i].checked="true")
      {
        document.checks.OGname[i].name="newname";
      }else{
        i++;
      }
  }
  document.checks.submit();
}

正如我所说,没有保证或保证。

于 2009-05-28T00:53:09.570 回答
1

如果您提供更详细的场景描述会很棒,但我希望我的回答有用。

function sub_d()
{    
    for (i = 0; i < document.checks.OGname.length; i++) //for all check boxes
    {
        if (document.checks.OGname[i].type == 'CHECKBOX')
            if (document.checks.OGname[i].checked)
               {
                   document.checks.OGname[i].name="newname"; //change name of input 

               }    
    }    
    document.checks.submit();
}

我一般都是这样管理dom集合的:(不知道是不是最好的方式)

   function sub_d()
    {    
        var theInputs = document.checks.getElementsByTagName('input');
        for (var i = 0; i < theInputs.length; i++) 
        {
            if (theInputs[i].type == 'CHECKBOX')
                if (theInputs[i].checked)
                   {
                       theInputs[i].name="newname";         
                   }    
        }    
        document.checks.submit();
    }
于 2009-05-28T01:00:18.200 回答
0

在你们的帮助下,我想出了这个,似乎效果很好。让我知道它是否可以改进以供其他人使用...

function sub_d()
{

    for (i = 0; i < document.checks.OGname.length; i++) //for all check boxes
    {
        if (document.checks.OGname[i].checked == true)
        {
            document.checks.OGname[i].name="newname"; //change name of input data so we know it is for other function
            //By renaming the first element of the list, we have reduced the length of the list by one 
            //and deleted the first element. This is why we need to keep i at it's current position after a name change.
            i=i-1;  
        }
    }

    //When there is only one check box left it's propert length becomes undefined.
    //We will need this statement for the last undefined check box not covered in the for loop
    //We can no longer index user[0]
    document.checks.OGname.name="newname"; 

    document.checks.submit();//submit these checked values to the .exe

}
于 2009-05-28T17:47:31.960 回答