0

我正在使用在 Internet 上找到的以下示例来动态构建输入字段列表。

它似乎工作正常,但是当我提交表单时,我是否使用参数名称来放置来自 HttpServletRequest 的数据?

谢谢,罗伯

<HTML> 

<HEAD>     
<TITLE> Add/Remove dynamic rows in HTML table </TITLE>     

<SCRIPT language="javascript">         

function addRow(tableID) {               
    var table = document.getElementById(tableID);               
    var rowCount = table.rows.length;             
    var row = table.insertRow(rowCount);               
    var cell1 = row.insertCell(0);             
    var element1 = document.createElement("input");             
    element1.type = "checkbox";             
    cell1.appendChild(element1);               
    var cell2 = row.insertCell(1);             
    cell2.innerHTML = rowCount + 1;               
    var cell3 = row.insertCell(2);             
    var element2 = document.createElement("input");             
    element2.type = "text";             
    cell3.appendChild(element2);           
}           

function deleteRow(tableID) {             
    try {             
        var table = document.getElementById(tableID);             
        var rowCount = table.rows.length;               
        for(var i=0; i<rowCount; i++) {                 
            var row = table.rows[i];                 
            var chkbox = row.cells[0].childNodes[0];                 
            if(null != chkbox && true == chkbox.checked) {                     
                table.deleteRow(i);                     
                rowCount--;                     
                i--;                 
            }               
        }             
        }catch(e) {                 
            alert(e);             
        }         
    }       
</SCRIPT> 
</HEAD> 

<BODY>

<form name="myform" action="myServlet" method="post">

    <INPUT type="button" value="Add Row" onclick="addRow('dataTable')" />       
    <INPUT type="button" value="Delete Row" onclick="deleteRow('dataTable')" />       
    <TABLE id="dataTable" width="350px" border="1">         
    <TR>             
        <TD><INPUT type="checkbox" name="chk"/></TD>             
        <TD> 1 </TD>             
        <TD> 
            <INPUT type="text" /> 
        </TD>         
    </TR>     
    </TABLE>   

     <input type="submit" value="Go!"/>

</form>

</BODY> 
</HTML> 
4

1 回答 1

0

您需要为输入对象提供“名称”属性(如果您的 JSP 未使用名称,则为“id”,但我相信名称是首选)

试试这个:

function addRow(tableID) {               
    var table = document.getElementById(tableID);               
    var rowCount = table.rows.length;             
    var row = table.insertRow(rowCount);               
    var cell1 = row.insertCell(0);             
    var element1 = document.createElement("input");             
    element1.type = "checkbox";             
    element1.name = "chk_input";      //*** EDIT ***            
    cell1.appendChild(element1);               
    var cell2 = row.insertCell(1);             
    cell2.innerHTML = rowCount + 1;               
    var cell3 = row.insertCell(2);             
    var element2 = document.createElement("input");             
    element2.type = "text";
    element2.name = "text_input";     //*** EDIT ***
    cell3.appendChild(element2);           
}

然后你的参数将被命名为“text_input”和“chk_input”。你当然可以用更有意义的东西来代替它。

我有一段时间没有使用 JSP(我假设这就是 HttpServletRequest 的意义所在……)所以我不记得如何访问它们,但这些将是关键。

编辑:如果您要动态添加行,我想您需要一个唯一的名称。看来您正在跟踪行数,因此您可以执行以下操作:

 ...
 element2.name = 'text-input-' + rowCount;
 ...

然后在您的控制器中(无论处理表单),您都可以使用 rowCount 设置一个循环(对于 i .. rowcount),您可以在其中检查表单中每一行的“text-input-”+ CastToString(i) 之类的键.

如果您没有将 rowCount 与表单一起传递,只需添加一个 hidden 类型的输入,其 name='rowCount' 和 rowCount var 的值。您可以在用户单击提交按钮时执行此操作,因此您不必更新每一行)

form = document.getElementById('myform');
rc = document.createElement('input');
rc.type = 'hidden'
rc.value = rowCount; // make sure it's in scope!!!
form.appendChild(rc);
于 2012-04-05T16:07:34.550 回答