我的网站结构是这样的:插入HTML动态与JSTL
引入了menu.jsp
...
`<li id="menu"><a href="index.jsp?page=pizzas"><i class="fa fa-angle-double-right"></i>Pizzas</a></li>`
...
的index.jsp
...
<c:when test="${param.page == 'pizzas'}">
<jsp:include page="/pages/cadastro/pizzas.jsp" />
</c:when>
...
pizzas.jsp
<c:forEach var="pizza" items="${pizzas}">
<td data-title="#">${pizza.id}</td>
<td data-title="Description">${pizza.description}</td>
<td data-title="Type">${pizza.type}</td>
</c:forEach>
当我试图在上插入html时,我的问题就发生了pizzas.jsp:我该如何使用一个servlet来填充我的<td>
的?它应该在哪里被调用?我想过上调用一个函数ajax
时pizzas.jsp
准备这样的:
$(document).ready(function() {
$.ajax({
url: "PizzaController?action=listPizzas",
type: 'GET',
success: function (result) {
},
complete: function() {
alert('complete');
}
});
}
,在我的Servlet(PizzaController
):
private void listPizzas(HttpServletRequest request, HttpServletResponse response) {
List<Pizza> pizzas = new ArrayList<>();
try {
pizzas = pizzaDaoImpl.findAll();
} catch (Exception e){
System.out.println(e.getMessage());
}
request.setAttribute("pizzas", pizzas);
try {
RequestDispatcher rd = request.getRequestDispatcher("/index.jsp?page=pizzas");
rd.forward(request,response);
} catch (IOException e1) {
e1.printStackTrace();
} catch (ServletException e){
e.printStackTrace();
}
}
做这种方式的问题在于,pizzas.jsp将被调用两次:1)在菜单上点击; 2)在ajax调用。
那么,在这种情况下插入dynamyc html的最佳方式是什么?
实际问题是什么?你是否试图避免重新加载页面来更新pizzas.jsp中显示的表格?要根据点击按钮动态更新表格? – MarGar 2014-10-10 06:24:06