4

同じ名前のテキストボックスの値をJSPからサーブレットに渡そうとしていますが、このタスクを実行できません。

これをサーブレットで使用しようとしましたが、テキストボックスの値が1つしかありません。

String[] words = request.getParameterValues("words");
String[] meanings = request.getParameterValues("meaning");

複数のテーブル行を生成するのに役立つ私のJavaScriptは次のとおりです。

<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);
            var element2 = document.createElement("input");
            element2.type = "text";

            cell2.appendChild(element2);

            var cell3 = row.insertCell(2);
            var element3 = document.createElement("input");
            element3.type = "text";
            cell3.appendChild(element3);

        }

        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>

複数の行を生成するHtmlテーブル:-

</body>
<form name="managelist" action="../createlistpath" method="post">

    <TABLE id="dataTable" width="600px" border="0">
    <tr>
    <td><b> List Name</b></td>
    <td colspan="2"><input type="text" name="listname"></td>
    </tr>

    <tr >
        <td><b>Select</b></td>
        <td><b>Word</b></td>
        <td><b>Meaning</b></td>
    </tr>
        <TR >
            <TD><INPUT type="checkbox" name="checkbox"/></TD>
            <TD> <INPUT type="text" name="words" /> </TD>
            <TD> <INPUT type="text" name="meaning" /> </TD>
        </TR>
    </TABLE>

 <INPUT type="button" value="Add Row" onclick="addRow('dataTable')" />

    <INPUT type="button" value="Delete Row" onclick="deleteRow('dataTable')" />
<br>
<input type="submit" value = "submit" name="submit">

</form>
</body>
4

2 に答える 2

5

動的に作成された入力要素に(「単語」または「意味」に)名前を付けないでください

        var element2 = document.createElement("input");
        element2.name = "words";
        element2.type = "text";
        cell2.appendChild(element2);
于 2012-05-02T20:45:04.283 に答える
5

そのようなフォームがある場合:

<form method="post">
    <input type="text" name="words"><br>
    <input type="text" name="words"><br>
    <input type="submit">
</form>

テキストボックスに1つと2つ入れれば送信します

words=one&words=two

取得するために、

String[] words = request.getParameterValues("words");
于 2012-05-02T20:59:27.987 に答える