如何在表单提交后在下拉框中保留选定的值?

时间:2014-12-12 16:01:08

标签: java javascript html jsp drop-down-menu

在我发现的众多解决方案中,我似乎无法让他们中的任何一个为我工作。我的jsp文件中有一个下拉列表:

    <select name="chosenOne" onchange="javascript:getUsers(this.value);">  
            <option value="0" onclick="javascript:getUsers(this.value);">All Modules</option>
            <c:forEach items="${modules}" var="module"> 
                <option value="${module.id}"><c:out value="${module.title}"/></option>  
            </c:forEach>  
        </select></p> 

它从我的数据库动态填充,除了&#34;所有模块&#34;选项。这是onchange事件的javascript函数:

       <script type="text/javascript">
        function getUsers(id) { 
            if (id != "0"){
            document.updateForm.id.value = id;
            }
            else{
            document.updateForm.id.value = "0";
            }
            document.updateForm.submit(); 
        }</script>

这是我的servlet代码,它处理下拉框以及其他内容:

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

    long modID = 0;
    String url = "jsp/user/administration.jsp";
    request.setAttribute("modules", dataAccessor.getAllModules());

    if (isParameterValid(request.getParameter("id"))) {
        modID = Long.parseLong(request.getParameter("id"));
        request.setAttribute("users", getUsersFromModule(modID));
        System.out.println(modID);

    } else if (!isParameterValid(request.getParameter("id"))) {
        request.setAttribute("users", dataAccessor.getAllUsers());

    } else {
        request.setAttribute("errorMessage", "There was a problem retrieving users!");
        url = "jsp/error.jsp";
    }

    //request.setAttribute("formerSelect", modID);
    request.getRequestDispatcher(url).forward(request, response);
}

那么如何在表单刷新后让选定的下拉值保留在下拉框中?我已经设置了一个属性&#34;前选择&#34;它只包含下拉列表中先前所选项目的值。但是由于某种原因,当我试图将它分配给&#34;选择&#34;我的选项标签中的值。任何帮助深表感谢。

2 个答案:

答案 0 :(得分:3)

您需要在提交后将此参数传递给httpRequest:

request.setAttribute("selectedModule", request.getParameter("chosenOne"));

之后您需要将选项标记为已选择:

<c:forEach items="${modules}" var="module"> 
     <option value="${module.id}" ${module.id == selectedModule ? 'selected':''}>...</option>  
</c:forEach> 

答案 1 :(得分:0)

我可以这样解释。作为示例代码 把这段代码放在你的Servlet中

String status = request.getParameter("status");
request.setAttribute("status", status);

将此代码放入jsp文件

<select  id="status" name="status" class="listBx"  onChange = "check(this);">
                            <option value="" >--- Select ---</option>                           
                            <option value="1"  <%if((request.getAttribute("status") != null) && request.getAttribute("status").equals("1")){ %> selected <%} %>>Logged in</option>
                            <option value="0"  <%if((request.getAttribute("status") != null) && request.getAttribute("status").equals("0")){ %> selected <%} %>>Logged Out</option>
                        </select>