新聞中心
一般情況下開發(fā)jsp自定義標簽需要引用以下兩個包

創(chuàng)新互聯(lián)是一家專注于成都網站設計、網站建設與策劃設計,西藏網站建設哪家好?創(chuàng)新互聯(lián)做網站,專注于網站建設10余年,網設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:西藏等地區(qū)。西藏做網站價格咨詢:13518219792
import javax.servlet.jsp.*;
import javax.servlet.jsp.tagext.*;
首先我們需要大致了解開發(fā)自定義標簽所涉及到的接口與類的層次結構(其中SimpleTag接口與SimpleTagSupport類是JSP2.0中新引入的)。
目標1:自定義一個用表格顯示用戶信息的簡單標簽
效果圖:
在jsp頁面使用此自定義標簽:
假設我們有一個UserInfo的javabean,那么在JSP頁面使用此標簽只需調用此標簽即可
- <%
- UserInfo user = new UserInfo();
- user.setUserName("Xuwei");
- user.setAge(33);
- user.setEmail("[email protected]");
- pageContext.setAttribute("userinfo", user);
- %>
開發(fā)步驟:
簡單標簽的開發(fā)我們只要實現Tag接口即可,為了簡單起見可以直接繼承實現了此接口的TagSupport類
1 創(chuàng)建自定義標簽類
- public class UserInfoTag extends TagSupport {
- private UserInfo user;
- @Override
- public int doStartTag() throws JspException {
- try {
- JspWriter out = this.pageContext.getOut();
- if(user == null) {
- out.println("No UserInfo Found...");
- return SKIP_BODY;
- }
- out.println("
");
");- out.println("
"); ");- out.println("
Username: ");- out.println("
" + user.getUserName() + " ");- out.println("
- out.println("
"); ");- out.println("
Age: ");- out.println("
" + user.getAge() + " ");- out.println("
- out.println("
"); ");- out.println("
Email: ");- out.println("
" + user.getEmail() + " ");- out.println("
- out.println("
- } catch(Exception e) {
- throw new JspException(e.getMessage());
- }
- return SKIP_BODY;
- }
- @Override
- public int doEndTag() throws JspException {
- return EVAL_PAGE;
- }
- @Override
- public void release() {
- super.release();
- this.user = null;
- }
- //getter and setters
- public UserInfo getUser() {
- return user;
- }
- public void setUser(UserInfo user) {
- this.user = user;
- }
- }
2 在Web-Inf創(chuàng)建標簽庫描述文件.tdl(Tag Library Description)
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee web-jsptaglibrary_2_0.xsd">
1.0 2.0 cc /mytaglib showUserInfo com.mytags.UserInfoTag empty user false true
3 配置web.xml
/mytaglib /WEB-INF/mytaglib.tld
4 在需要使用此標簽的jsp頁面頭部引入
- <%@ taglib uri="/mytaglib" prefix="cc"%>
5 使用(參照上面的使用步驟)
此致,一個簡單的JSP標簽開發(fā)完成
標簽類說明:
我們創(chuàng)建的UserInfoTag類繼承了TagSupport類,而它又實現了Tag接口,Tag接口的生命周期由其所在的容器控制,如下圖:
setPageContext() 將所在jsp頁面的pageContext注入進來,目的是為了在后面的方法中可以訪問到jsp頁面對象的pageContext屬性
setParent() 設置此標簽的父標簽
setAttribute() 將標簽中的屬性注入到此class的屬性,不需要自己實現但要提供屬性的get與set方法
doStartTag() 在開始標簽屬性設置后調用,如果返回SKIP_BODY則忽略標簽之中的內容,如果返回EVAL_BODY_INCLUDE則將標簽體的內容進行輸出
doEndTag() 在結束標簽之前調用,返回SKIP_PAGE跳過整個jsp頁面后面的輸出,返回EVAL_PAGE執(zhí)行頁面余下部分
release() 生命周期結束時調用
特別說明:在tomcat4.1之后的版本中默認開啟了標簽緩沖池(websphere和weblogic并不會這么做),所以執(zhí)行完標簽后并不會執(zhí)行release()方法(_jspDestroy()時才釋放),也就是說同一個jsp頁面自定義標簽不管使用多少次只會存在一個實例,但也并不是每一個標簽都會為其創(chuàng)建一個緩沖池,要根據參數來判斷,例如:
上面例子中由于參數不同就會創(chuàng)建兩個標簽緩沖池。
這個問題可以通過設定tomcat的配置文件加以解決:
在%tomcat%\conf\web.xml加入enablePooling參數,并設置為false(不緩存自定義標簽)。
enablePooling false
清空%tomcat%\conf\目錄
#p#
TagSupport類已經為我們實現并擴展了一些方法(比如在上述方法中我們可以直接使用pageContext對象,調用父標簽getParent()等),所以一般情況下我們只需重寫doStartTag(),doEndTag() 即可
TLD文件說明:
Web.xml文件說明:
目標2:自定義一個類似于Asp.Net中的Reapter控件的標簽
效果圖:
在jsp頁面使用此自定義標簽:
- <%
- List
users = new ArrayList (); - users.add(new UserInfo("Zhangsan", 12, "[email protected]"));
- users.add(new UserInfo("Lisi", 22, "[email protected]"));
- users.add(new UserInfo("Wangwu", 33, "[email protected]"));
- pageContext.setAttribute("users", users);
- %>
UserName Age ${item.userName } ${item.age } ${item.email }
開發(fā)步驟:
要完成此控件我們需要實現一個迭代接口,即IterationTag,由于TagSupport同樣實現了此接口,所以我們繼承此類
1 創(chuàng)建自定義標簽類
- public class Repeater extends TagSupport {
- private Collection items;
- private Iterator it;
- private String var;
- @Override
- public int doStartTag() throws JspException {
- if(items == null || items.size() == 0) return SKIP_BODY;
- it = items.iterator();
- if(it.hasNext()) {
- pageContext.setAttribute(var, it.next());
- }
- return EVAL_BODY_INCLUDE;
- }
- @Override
- public int doAfterBody() throws JspException {
- if(it.hasNext()) {
- pageContext.setAttribute(var, it.next());
- return EVAL_BODY_AGAIN;
- }
- return SKIP_BODY;
- }
- @Override
- public int doEndTag() throws JspException {
- return EVAL_PAGE;
- }
- public void setItems(Collection items) {
- this.items = items;
- }
- public void setVar(String var) {
- this.var = var;
- }
- }
2在Web-Inf創(chuàng)建標簽庫描述文件.tdl(Tag Library Description)由于目標1種已經創(chuàng)建了此文件,我們只需增加此標簽的配置即可
repeater com.mytags.Repeater jsp items false true var true true
3 配置web.xml (目標1中已完成,無需修改)
#p#
4 在需要使用此標簽的jsp頁面頭部引入
- <%@ taglib uri="/mytaglib" prefix="cc"%>
5 使用(參照上面的使用步驟)
標簽類說明:
我們用到了迭代接口,以下是容器處理此接口的流程
作為目標1中的補充: 在doAfterBody()如果返回值是EVAL_BODY_AGAIN那么將重新執(zhí)行此方法
目標3:使用BodyTagSupport
此目標并不會使用實際例子進行顯示,主要是說明為什么,什么情況下需要使用到BodyTag接口或者BodyTagSupport類?
如果我們需要在 …. 之間的標簽體的頭部和尾部加上一些標記或者是其他處理,一般的處理方法是在doStartTag和doEndTag方法中進行, 但是如果是個迭代標簽,標簽體的每段內容在循環(huán)輸出時每次都需要在頭部和尾部加上一些標記,我們使用BodyTagSupport就很方便了,
此接口在doStartTag()方法返回值多了一個EVAL_BODY_BUFFERED,它將對主體進行計算,并輸出到緩沖區(qū)(注:此處是緩沖區(qū)并非直接輸出到客戶端,需要我們手動(this.bodyContent.getEnclosingWriter().write(this.bodyContent.getString());)進行輸出客戶端的調用,否則主體內容不會進行顯示)
標簽類說明:
關于BodyTagSupport接口的說明
目標4:自定義的函數庫
1 創(chuàng)建函數庫類
- public class MyFunctions {
- public static String formatMyName(String name) {
- return "your name is " + name;
- }
- public static int add(int a, int b) {
- return a+b;
- }
- }
2 在TLD文件中配置 (引用于目標1中的tld文件)
formatMyName com.taglib.MyFunctions java.lang.String formatMyName(java.lang.String) add com.taglib.MyFunctions java.lang.String add(int, int)
3 JSP中調用
- ${cc:formatMyName("wangfei") }
- ${cc:add(12, 34) }
原文:http://www.cnblogs.com/zhaoyang/archive/2011/12/25/2301108.html
當前題目:JSP自定義標簽開發(fā)入門
文章來源:http://m.fisionsoft.com.cn/article/djjhedi.html


咨詢
建站咨詢
