使用“单个提交”按钮发送多个下拉列表值

时间:2017-01-24 06:55:35

标签: java forms jsp submit dropdown

我试图制作一个看起来像这样的表格。每行有两个下拉列表:第一行只选择一个,另一个是选择多个。 Here is the output screen.

在此屏幕中,我想使用单个提交按钮将所有行的值(包括两个下拉列表)发送到servlet(Testing.java)。在Testing.java中,我基本上希望能够访问与每个测试名称对应的每一行的所有值。

这是我在imageimage中显示输出的JSP代码:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1" import = "java.util.*" pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">

        <link rel="stylesheet" href="jquery chosen utils/chosen.css">  
        <link rel="stylesheet" type="text/css" href="jquery chosen utils/welcomestyle.css">
    </head>
    <body>
        <div align = center>
            <table style="width: 100%">
                <tr>
                    <th> Script Name </th>
                    <th> Main Action Keywords </th>
                    <th> Sub Action Keywords </th>
                </tr>
            </table>
            <%
            for(int i =0; i<5;i++)
            {
            %>
            <form action = "Testing">
            <table style="width: 100%">
                <tr>
                    <td> Test <%= i %> </td>
                    <td> 
                        <div>
                            <select name = "Actions" class = "Actions" >
                                <%
                                for(int j=0;j<4;j++)
                                {
                                %>
                                <option value="Action<%= j %>">
                                    Action <%= j %>
                                </option>
                                <%
                                }
                                %>
                            </select>
                        </div>  
                    </td>
                    <td> 
                        <select name = "SubActions" class = "SubActions" multiple>
                            <%
                            for(int k=0;k<4;k++)
                            {
                            %>
                            <option value="SubAction<%= k %>">
                                Sub Action <%= k %>
                            </option>
                            <%
                            }
                            %>
                        </select>
                    </td>
                </tr>
            </table>
            <%
            } 
            %>
            <br><br>
            <input type = submit value = "Submit" name ="submit" />
        </form>
    </div>
</body>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
<script src="jquery chosen utils/chosen.jquery.js" type="text/javascript"></script>
<script src="jquery chosen utils/prism.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
        $(document).ready(function(){
            $(".Actions").chosen({
                width: "75%"
            });
            $(".SubActions").chosen({
                width: "75%"
            });
        });
    </script>
</html>

我希望我的Testing.java是这样的:

import java.io.IOException;
import java.util.ArrayList;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/Testing")
public class Testing extends HttpServlet
{

private static final long serialVersionUID = 1L;

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
{


    String a = request.getParameter("Actions"); //Should get actions corrsponding to each test 
    String b = request.getParameter("SubActions"); //Should get subactions corrsponding to each test


   }   
}

Current Testing.java仅返回第一行的动作和第一个子动作(Test 0)。 我主要使用带有一点jQuery的HTML进行下拉菜单。

任何人都可以就如何做同样的建议吗?

2 个答案:

答案 0 :(得分:0)

您要找的是操作Array子操作2D Array

对于子操作也是

变化:
<select name = "SubActions" class = "SubActions" multiple>
于:
<select name = "SubActions[<%= i %>]" class = "SubActions" multiple>

要访问Servlet中的值,请执行以下操作:

String[] actions =request.getParameterValues('Actions');
int length = 5 ;       // Length of Rows
String[][] subActions = new String[length][];

for (int i = 0; i < length; i++) {
    subActions[i] = request.getParameterValues("SubActions["+i+"]");
}

我可以看到 5 的循环用于创建行,因此它是固定的 如果您的行(选择动态/可增长 Servlet 中,您需要以动态方式访问它。然后在Servlet中动态更改长度:

int length = 0 ;       // Length of Rows
if( actions != null )
    length = actions.length;     // Calculate Rows Dynamic

答案 1 :(得分:0)

我终于找到了一种使用Shantaram的想法来访问每个动作和子动作的方法,尽管它并不完全正确。

为了完善他的想法,我做了以下改动:

<select name = "Actions[<%= i %>]" class = "Actions" >

<select name = "SubActions[<%= i %>]" class = "SubActions" multiple>

对我来说,以下不起作用:

String actions[] = request.getParameterValues("Actions");

为了访问它们,我做了以下事情:

String actions[] = new String[5];
for (i = 0; i < 5; i++)
        actions[i] = request.getParameter("Actions["+i+"]");

String[][] subActions = new String[5][];
    for (i = 0; i < length; i++) 
        subActions[i] = request.getParameterValues("SubActions["+i+"]");

欢迎任何更好的方式。