本文实例讲述了jsp通过自定义标签库实现数据列表显示的方法。分享给大家供大家参考,具体如下:
1. 定义标签库类 UserListTag.java
package com.yanek.cms.tag; import java.io.IOException; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import javax.servlet.jsp.JspException; import javax.servlet.jsp.tagext.BodyTagSupport; import com.yanek.cms.vo.UserInfo; public class UserListTag extends BodyTagSupport { private String name;// 一个属性名 private Iterator it;// 要迭代的对象 private int cateid; // 用户类别id @Override public int doEndTag() throws JspException { try { if (bodyContent != null) { bodyContent.writeOut(bodyContent.getEnclosingWriter()); } } catch (IOException e) { e.printStackTrace(); } return EVAL_PAGE; } @Override public int doStartTag() throws JspException { //这里根据用户类型,构造不同的列表数据,实现可以根据数据库获取 List<UserInfo> users = new ArrayList<UserInfo>(); if (cateid == 1) { users.add(new UserInfo("张三", 20, "Zhangsan@163.com")); users.add(new UserInfo("李四", 30, "Lisi@sina.com")); } else { users.add(new UserInfo("王五", 33, "Wangwu@qq.com")); users.add(new UserInfo("赵六", 33, "zhaoliu@qq.com")); } it = users.iterator(); if (it == null) { return SKIP_BODY; } else { return continueNext(); } } private int continueNext() { if (it.hasNext()) { pageContext.setAttribute(name, it.next(), pageContext.PAGE_SCOPE); return EVAL_BODY_TAG; } else { return SKIP_BODY; } } @Override public int doAfterBody() { return continueNext(); } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getCateid() { return cateid; } public void setCateid(int cateid) { this.cateid = cateid; } }
2. 在WEB-INF目录下 新建标签库描述文件my_cms_tag.tld:
my_cms_tag.tld
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.1//EN" "http://java.sun.com/j2ee/dtds/web-jsptaglibrary_1_1.dtd"> <taglib> <tlibversion>1.0</tlibversion> <jspversion>1.0</jspversion> <shortname>cms</shortname> <uri>http://www.58tech.cn/mystruts/tags-cms</uri> <!-- userListTag start --> <tag> <name>userListTag</name> <tag-class>com.yanek.cms.tag.UserListTag</tag-class> <body-content>jsp</body-content> <variable> <!--<name-given>user_info</name-given>--> <name-from-attribute>name</name-from-attribute> <variable-class>com.yanek.cms.vo.UserInfo</variable-class> <declare>true</declare> <scope>NESTED</scope> </variable> <attribute> <name>name</name> <required>true</required> </attribute> <attribute> <name>cateid</name> <required>true</required> </attribute> </tag> <!-- userListTag end --> </taglib>
3. web.xml配置
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" 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-app_2_5.xsd"> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <taglib> <taglib-uri>/tags/my-cms</taglib-uri> <taglib-location>/WEB-INF/my_cms_tag.tld</taglib-location> </taglib> </web-app>
4. jsp调用
<%@ page language="java" import="java.util.*,com.yanek.cms.vo.*" pageEncoding="UTF-8"%> <%@ taglib uri="/tags/my-cms" prefix="myTag" %> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'test.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <table width='500px' border='1' align='center'> <tr> <td width='20%'>UserName</td> <td width='20%'>Age</td> <td>Email</td> </tr> <myTag:userListTag name="user_info1" cateid="1"> <tr> <td><%=user_info1.getUserName() %></td> <td><%=user_info1.getAge() %></td> <td><%=user_info1.getEmail() %> </td> </tr> </myTag:userListTag> </table> <hr> <table width='500px' border='1' align='center'> <tr> <td width='20%'>UserName</td> <td width='20%'>Age</td> <td>Email</td> </tr> <myTag:userListTag name="user_info2" cateid="2"> <tr> <td><%=user_info2.getUserName() %></td> <td><%=user_info2.getAge() %></td> <td><%=user_info2.getEmail() %> </td> </tr> </myTag:userListTag> </table> </body> </html>
实体类定义
package com.yanek.cms.vo; public class UserInfo { private int age; private String userName; private String email; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public UserInfo(String userName,int age, String email) { super(); this.age = age; this.userName = userName; this.email = email; } public UserInfo() { } }
运行效果如下图 (URL输入:http://127.0.0.1:8080/TestCMS/page/userlist.jsp)
完整实例代码代码点击此处本站下载。
希望本文所述对大家Android程序设计有所帮助。
主要内容:自定义标签的语法,简单示例,tld标签库描述文件,自定义标签属性,自定义标签的标签体自定义标签就是用户(开发者)自己定义的标签。自定义标签可以让 JSP 页面中不含有 Java 代码,只含有 HTML 代码和部分标签,就能实现业务逻辑的调用。 自定义标签的优点如下: 减少 JSP 页面对脚本的需求和依赖性 将 JSP 页面和业务逻辑分开,增加了程序的可维护性 可重复调用相同的业务逻辑,增加了程序的可重用性 使用自定义标签步骤如下: 自定义标签实现类 编写 tld 标签库描述文件
自定义标签是用户定义的JSP语言元素。当JSP页面包含一个自定义标签时将被转化为servlet,标签转化为对被 称为tag handler的对象的操作,即当servlet执行时Web container调用那些操作。 JSP标签扩展可以让你创建新的标签并且可以直接插入到一个JSP页面。 JSP 2.0规范中引入Simple Tag Handlers来编写这些自定义标记。 你可以继承SimpleTa
本文向大家介绍JSP实现用于自动生成表单标签html代码的自定义表单标签,包括了JSP实现用于自动生成表单标签html代码的自定义表单标签的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JSP实现用于自动生成表单标签html代码的自定义表单标签。分享给大家供大家参考。具体如下: 这个是自己写的一个简单的JSP表单标签,用于自动生成checkbox,select,radio等标签,传入菜单集
本文向大家介绍Vue实现用户自定义字段显示数据的方法,包括了Vue实现用户自定义字段显示数据的方法的使用技巧和注意事项,需要的朋友参考一下 如下: 代码: 以上这篇Vue实现用户自定义字段显示数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
问题内容: 当前,大多数主流浏览器(Safari除外)都支持HTML5 元素,这似乎是一种向输入添加建议的有趣方式。 但是,value属性的实现与上的内部文本之间似乎存在一些差异。例如: 选择一个后,输入将填充值而不是内部文本。我只希望用户在下拉列表和输入中看到文本(“答案”),但42像那样select将值传递给Submit。 如何使所有浏览器的下拉列表显示 的标签(内部文本),但在 提交valu
目前HTML5
本文向大家介绍vue.js通过自定义指令实现数据拉取更新的实现方法,包括了vue.js通过自定义指令实现数据拉取更新的实现方法的使用技巧和注意事项,需要的朋友参考一下 前言 这篇文章的代码片段位于 vue 的单文件组件中,即以 .vue 结尾的文件中,本文说明的只是一种实现方法,既不是唯一的方法也不是最好的方法,如果大家有更好的方法可以留言,大家进行讨论。 第一步 首先,一定要先定义变量: 第二步
为什么即使在接口中可用也不公开? 另外,是否有一种方法可以动态地/以编程方式添加要通过REST公开的资源库?