我正在创建一个自定义标记指令,我必须从数据库中打印一个数据表。
到目前为止,我已经创建了一个JSP页面
<%@taglib uri="/WEB-INF/tlds/fact.tld" prefix="veritis"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>JSP Page</title>
</head>
<body>
<h1><veritis:print name="emp" /></h1>
</body>
</html>
和tld文件
<?xml version="1.0" encoding="UTF-8"?>
<taglib version="2.1" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd">
<tlib-version>1.0</tlib-version>
<short-name>factorial</short-name>
<tag>
<name>print</name>
<tag-class>com.veritis.jsp.FactTag</tag-class>
<body-content>empty</body-content>
<attribute>
<name>name</name>
<required>false</required>
</attribute>
</tag>
</taglib>
和一个Class文件,使用其他Class文件从数据库中获取数据。此类文件还扩展TagSupport
以覆盖所需的tld方法
public class FactTag extends TagSupport{
String value="emp";
public String getValue() {
return value; }
public void setValue(String value) {
this.value = value;
}
public int doStartTag(){
return Tag.SKIP_BODY;
}
public int doEndTag() throws JspTagException{
String emp1=getValue();
try{
//The following line is to get the JSP Writer Object
//similar to PrintWriter in Servlet
JspWriter out=pageContext.getOut();
TableData tbd=new TableData();
List<Employee> listOfEmp=tbd.getAllEMployees();
for(Employee emp:listOfEmp)
{
System.out.println(emp);
}
}catch(Exception e){}
return Tag.SKIP_PAGE;
}
}
现在我的List<emp>
中有数据,我想在JSP文件中打印它。我可以通过使用out对象来打印它,但我的要求是不要使用out对象而是通过包含其他JSP文件或任何其他方式进行打印。
注意:虽然我从JSP中获取input(emp)
,但我现在还没有使用它。相反,我正在生成一个静态查询来获取数据
答案 0 :(得分:0)
您可以使用JSTL c:forEach
标记来遍历Employee
列表。如果您不想使用基于Struts2或Spring MVC等servlet的框架,您可以使用原始servlet
@WebServlet("/employees")
public class HomeServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
TableData tbd=new TableData();
List<Employee> listOfEmp=tbd.getAllEMployees();
request.setAttribute("listOfEmp", listOfEmp);
RequestDispatcher rd = getServletContext().getRequestDispatcher("/emloyee.jsp");
rd.forward(request, response);
}
}
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>JSP Page</title>
<style>
table,th,td
{
border:1px solid black;
}
</style>
</head>
<body>
<%-- Using JSTL c:forEach and c:out to loop a list and display items in a table --%>
<table>
<tbody>
<tr><th>ID</th><th>Name</th><th>Role</th></tr>
<c:forEach items="${requestScope.listOfEmp}" var="emp">
<tr><td><c:out value="${emp.id}"></c:out></td>
<td><c:out value="${emp.name}"></c:out></td>
<td><c:out value="${emp.role}"></c:out></td></tr>
</c:forEach>
</tbody>
</table>
<br><br>
</body>
</html>
您还可以使用包含表的JSP片段页面并将其包含在主页面中。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>JSP Page</title>
<style>
table,th,td
{
border:1px solid black;
}
</style>
</head>
<body>
<c:import url="employee_table.jsp"/>
<br><br>
</body>
</html>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%-- Using JSTL c:forEach and c:out to loop a list and display items in a table --%>
<table>
<tbody>
<tr><th>ID</th><th>Name</th><th>Role</th></tr>
<c:forEach items="${requestScope.listOfEmp}" var="emp">
<tr><td><c:out value="${emp.id}"></c:out></td>
<td><c:out value="${emp.name}"></c:out></td>
<td><c:out value="${emp.role}"></c:out></td></tr>
</c:forEach>
</tbody>
</table>