在傳統的JSP程式中,我們將HTML代碼與Java代碼混合在一起編寫,這樣雖然方便,但同時也導致頁面難以維護,HTML開發人員和JSP開發人員負擔加重,我們可以將這種傳統的技術成為頁面拉資料技術。 怎樣才能做到將HTML開發和JSP開發分離呢?答案就是使用Tag技術,通過使用Tag技術,我們就可以在頁面程式中不出現JSP代碼,在需要資料的地方,大家先約定好標籤,然後由Tag的幕後處理程式去替換這些標籤,顯示資料。我稱這種技術叫做向頁面推資料,頁面只要定義好格式就行了。這樣,我們可以讓HTML開發人員專註於頁面的外觀,而Java程式員則不用理會頁面顯示,專註於背景程式,大大提高了程式的可維護性和方便性。便於各程式員之間的協作開發。 首先你要懂一些Tag技術,然後才能閱讀本文。下面是範例程式: 一、首先是替換字串的replace函數 // 替換字串函數 // String strSource - 源字串 // String strFrom - 要替換的子串 // String strTo - 替換為的字串 public static String replace(String strSource, String strFrom, String strTo) { // 如果要替換的子串為空白,則直接返回源串 if(strFrom == null || strFrom.equals("")) return strSource; String strDest = ""; // 要替換的子串長度 int intFromLen = strFrom.length(); int intPos; // 迴圈替換字串 while((intPos = strSource.indexOf(strFrom)) != -1) { // 擷取匹配字串的左邊子串 strDest = strDest + strSource.substring(0,intPos); // 加上替換後的子串 strDest = strDest + strTo; // 修改源串為匹配子串後的子串 strSource = strSource.substring(intPos + intFromLen); } // 加上沒有匹配的子串 strDest = strDest + strSource; // 返回 return strDest; } 二、Tld文(MyBookTag.tld) 定義你的標籤 <?xml version="1.0" encoding="ISO-8859-1" ?> <!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd"> <taglib> <tlib-version>1.0</tlib-version> <jsp-version>1.2</jsp-version> <short-name></short-name> <tag> <name>ListBook</name> <tag-class>com.book.taglib.ListBookTag</tag-class> <body-content>JSP</body-content> </tag> </taglib>
三、Tag的幕後處理檔案,負責解釋標籤(ListBookTag.java)
package com.book.taglib; import java.util.*; import java.lang.*; import com.book.model.bookmodel; import com.book.utils.StringHelper; import javax.servlet.jsp.JspTagException; import javax.servlet.jsp.tagext.BodyTagSupport; import javax.servlet.jsp.tagext.BodyContent; import javax.servlet.jsp.PageContext; import javax.servlet.jsp.JspWriter; import javax.servlet.ServletRequest; public class ListBookTag extends BodyTagSupport { // 標誌開始位置執行 public int doStartTag(){ return EVAL_BODY_BUFFERED; } // 標誌結束位置執行 public int doEndTag()throws JspTagException { int max = 0; String ListBody = null; int number = 1; // 擷取頁碼資訊,也就是request對象中的內容 String serialNo = pageContext.getRequest().getParameter("serialNo"); // 轉換為整數 try{ number = Integer.parseInt(serialNo); } catch(Exception e){ number = 1; } if (number < 1) number = 1; // 擷取儲存在Session中的資料集,當然這裡也可以從資料庫中取資料 Vector bookVector = (Vector)pageContext.getSession().getAttribute("bookVector"); if(number*10<bookVector.size()) max = number*10; else max = bookVector.size(); if(bookVector.size()>0){ // 擷取標籤內部的內容 BodyContent bc = getBodyContent(); for (int i = (number - 1) * 10; i < max; i++) { // 擷取一條記錄 bookmodel model = (bookmodel) bookVector.get(i); if (model == null) model = new bookmodel(); // 替換內容(就是在這裡輸出資料的,替換) String body = bc.getString(); body = StringHelper.replace(body, "$_SerialNo", model.getBookid()); body = StringHelper.replace(body, "$_BookName", model.getBookname()); body = StringHelper.replace(body, "$_Author", model.getAuthor()); body = StringHelper.replace(body, "$_PHouse", model.getPhouse()); body = StringHelper.replace(body, "$_Price", model.getPrice().toString()); body = StringHelper.replace(body, "$_index", Integer.toString(i)); // 向頁面輸出 try{ pageContext.getOut().print(body); } catch(Exception e){ } } } return EVAL_PAGE; } } 四、JSP頁面(BookList.jsp) <%@page contentType="text/html; charset=GBK"%> <%@ taglib uri="/MyBookTag" prefix="MyBookTag" %> <html> <head> <title>一個基於J2EE的圖書DEMO</title> <script language="javascript"> function returnBack(){ document.form1.action = "BookAdmin.jsp"; } </script> </head> <body bgcolor="#FFFFFF" text="#000000" leftmargin="0" topmargin="0"> <h2 align="center"><font face="黑體" color="#0000CC">圖書列表</font></h2> <form name="form1" method="post"> <table width="750" border="1" cellspacing="0" align="center" cellpadding="3" bordercolor="#A5ABB6" bordercolordark="#ffffff"> <tr align="center"> <td width="100" bgcolor="FEFBF4" height="41">序號</td> <td width="200" bgcolor="FEFBF4" height="41">圖示名稱</td> <td width="100" bgcolor="FEFBF4" height="41">圖書作者</td> <td width="200" bgcolor="FEFBF4" height="41">出版社</td> <td width="50" bgcolor="FEFBF4" height="41">圖書價格</td> <td width="100" bgcolor="FEFBF4" height="41">操作</td> </tr> <!--這裡使用標籤技術,如果不用,就麻煩了,相信您一定有感觸--> <MyBookTag:ListBook> <tr align="center"> <td width="100" height="19">$_SerialNo</td> <td width="200" height="19">$_BookName</td> <td width="100">$_Author</td> <td width="200">$_PHouse</td> <td width="50" height="19">$_Price</td> <td width="100" height="19" align="left"> <a href="bookEditTable.jsp?ItemNo=$_index"> <font color="#0000CC">編輯</font> </a> |<a href="bookview.jsp?ItemNo=$_index"> <font color="#FF0000">查看</font> </a> </td> </tr> </MyBookTag:ListBook> </table> <table width="400" border="0"> <tr> <td width="100%" align="right"> <div align="right"> <input type="submit" name="Submit" value="返回" onClick="javascript:returnBack();" class="annew1"> </div> </td> </tr> </table> </form> <p align="left"> </p> </body> </html |