自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JSP源碼技術(shù)之頁面與代碼分離

開發(fā) 后端
頁面與代碼分離這一特性如何在JSP源碼中得以實現(xiàn)呢?那么本文將給你一個答案。

在傳統(tǒng)的JSP源碼程序中,頁面與代碼分離還不是很普遍的應用我們將HTML代碼與Java代碼混合在一起編寫,這樣雖然方便,但同時也導致頁面難以維護,HTML開發(fā)人員和JSP開發(fā)人員負擔加重,我們可以將這種傳統(tǒng)的技術(shù)成為頁面拉數(shù)據(jù)技術(shù)。

怎樣才能做到將HTML源碼開發(fā)和JSP源碼開發(fā)分離呢?答案就是使用Tag技術(shù),通過使用Tag技術(shù),我們就可以實現(xiàn)頁面與代碼分離,在需要數(shù)據(jù)的地方,大家先約定好標簽,然后由Tag的后臺處理程序去替換這些標簽,顯示數(shù)據(jù)。我稱這種技術(shù)叫做向頁面推數(shù)據(jù),頁面只要定義好格式就行了。這樣,我們可以讓HTML開發(fā)人員專注于頁面的外觀,而Java程序員則不用理會頁面顯示,專注于后臺程序,大大提高了程序的可維護性和方便性。便于各程序員之間的協(xié)作開發(fā)。

首先你要懂一些Tag技術(shù),然后才能閱讀本文。下面是樣例程序:

一、替換字符串的replace函數(shù)

通過這個函數(shù)的使用來開始我們的頁面與代碼分離。

  1. // 替換字符串函數(shù)  
  2. // String strSource - 源字符串  
  3. // String strFrom   - 要替換的子串  
  4. // String strTo     - 替換為的字符串  
  5. public static String replace(String strSource, String strFrom, String strTo)  
  6. {  
  7.       // 如果要替換的子串為空,則直接返回源串  
  8.       if(strFrom == null || strFrom.equals(""))  
  9.           return strSource;  
  10.       String strDest = "";  
  11.       // 要替換的子串長度  
  12.       int intFromLen = strFrom.length();  
  13.       int intPos;  
  14.       // 循環(huán)替換字符串  
  15.       while((intPos = strSource.indexOf(strFrom)) != -1)  
  16.       {  
  17.           // 獲取匹配字符串的左邊子串  
  18.           strDeststrDest = strDest + strSource.substring(0,intPos);  
  19.           // 加上替換后的子串  
  20.           strDeststrDest = strDest + strTo;  
  21.           // 修改源串為匹配子串后的子串  
  22.           strSourcestrSource = strSource.substring(intPos + intFromLen);  
  23.       }  
  24.       // 加上沒有匹配的子串  
  25.       strDeststrDest = strDest + strSource;  
  26.       // 返回  
  27.       return strDest;  
  28. }  
  29.  

二、Tld文(MyBookTag.tld) 定義你的標簽

標簽的定義也是在JSP源碼中實現(xiàn)頁面與代碼分離的重要一步。

  1. ﹤?xml version="1.0" encoding="ISO-8859-1" ?﹥  
  2. ﹤!DOCTYPE taglib  
  3.         PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN"  
  4.         "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd"﹥  
  5. ﹤taglib﹥  
  6. ﹤tlib-version﹥1.0﹤/tlib-version﹥  
  7. ﹤jsp-version﹥1.2﹤/jsp-version﹥  
  8. ﹤short-name﹥﹤/short-name﹥  
  9. ﹤tag﹥  
  10.     ﹤name﹥ListBook﹤/name﹥  
  11.     ﹤tag-class﹥com.book.taglib.ListBookTag﹤/tag-class﹥  
  12.     ﹤body-content﹥JSP﹤/body-content﹥  
  13. ﹤/tag﹥  
  14. ﹤/taglib﹥  
  15.  

三、Tag的后臺處理文件,負責解釋標簽(ListBookTag.java)

  1. package com.book.taglib;  
  2.  
  3. import java.util.*;  
  4. import java.lang.*;  
  5.  
  6. import com.book.model.bookmodel;  
  7. import com.book.utils.StringHelper;  
  8.  
  9. import javax.servlet.jsp.JspTagException;  
  10. import javax.servlet.jsp.tagext.BodyTagSupport;  
  11. import javax.servlet.jsp.tagext.BodyContent;  
  12. import javax.servlet.jsp.PageContext;  
  13. import javax.servlet.jsp.JspWriter;  
  14. import javax.servlet.ServletRequest;  
  15.  
  16. public class ListBookTag extends BodyTagSupport {  
  17.  
  18.    // 標志開始位置執(zhí)行  
  19.    public int doStartTag(){  
  20.      return EVAL_BODY_BUFFERED;  
  21.    }  
  22.    // 標志結(jié)束位置執(zhí)行  
  23.    public int doEndTag()throws JspTagException {  
  24.      int max = 0;  
  25.      String ListBody = null;  
  26.      int number = 1;  
  27.     // 獲取頁碼信息,也就是request對象中的內(nèi)容  
  28.      String serialNo = pageContext.getRequest().getParameter("serialNo");  
  29.     // 轉(zhuǎn)換為整數(shù)  
  30.      try{  
  31.        number = Integer.parseInt(serialNo);  
  32.      }  
  33.      catch(Exception e){  
  34.        number = 1;  
  35.      }  
  36.      if (number ﹤ 1)  
  37.          number = 1;  
  38.      // 獲取保存在Session中的數(shù)據(jù)集,當然這里也可以從數(shù)據(jù)庫中取數(shù)據(jù)  
  39.      Vector bookVector = (Vector)pageContext.getSession().getAttribute("bookVector");  
  40.      if(number*10﹤bookVector.size())  
  41.          max = number*10;  
  42.      else  
  43.          max = bookVector.size();  
  44.      if(bookVector.size()﹥0){  
  45.          // 獲取標簽內(nèi)部的內(nèi)容  
  46.          BodyContent bc = getBodyContent();  
  47.          for (int i = (number - 1) * 10; i ﹤ max; i++) {  
  48.            // 獲取一條記錄  
  49.            bookmodel model = (bookmodel) bookVector.get(i);  
  50.            if (model == null)  
  51.              model = new bookmodel();  
  52.            // 替換內(nèi)容(就是在這里輸出數(shù)據(jù)的,替換)  
  53.            String body = bc.getString();  
  54.            body = StringHelper.replace(body, "$_SerialNo", model.getBookid());  
  55.            body = StringHelper.replace(body, "$_BookName", model.getBookname());  
  56.            body = StringHelper.replace(body, "$_Author", model.getAuthor());  
  57.            body = StringHelper.replace(body, "$_PHouse", model.getPhouse());  
  58.            body = StringHelper.replace(body, "$_Price", model.getPrice().toString());  
  59.            body = StringHelper.replace(body, "$_index", Integer.toString(i));  
  60.            // 向頁面輸出  
  61.            try{  
  62.              pageContext.getOut().print(body);  
  63.            }  
  64.            catch(Exception e){  
  65.  
  66.            }  
  67.          }  
  68.       }  
  69.      return EVAL_PAGE;  
  70.    }  
  71. }  
  72.  

四、頁面JSP源碼(BookList.jsp)

至此我們可以操作JSP來實現(xiàn)頁面與代碼分離。

  1. ﹤%@page contentType="text/html; charset=GBK"%﹥  
  2. ﹤%@ taglib uri="/MyBookTag" prefix="MyBookTag" %﹥  
  3. ﹤html﹥  
  4. ﹤head﹥  
  5. ﹤title﹥一個基于J2EE的圖書DEMO﹤/title﹥  
  6.  
  7. ﹤script language="javascript"﹥  
  8. function returnBack(){  
  9.     document.form1.action = "BookAdmin.jsp";  
  10. }  
  11. ﹤/script﹥  
  12.  
  13. ﹤/head﹥  
  14. ﹤body bgcolor="#FFFFFF" text="#000000" leftmargin="0" topmargin="0"﹥  
  15.  
  16.  
  17. ﹤h2 align="center"﹥﹤font face="黑體" color="#0000CC"﹥圖書列表﹤/font﹥﹤/h2﹥  
  18. ﹤form name="form1" method="post"﹥  
  19. ﹤table width="750" border="1" cellspacing="0" align="center" cellpadding="3" bordercolor="#A***BB6" bordercolordark="#ffffff"﹥  
  20.     ﹤tr align="center"﹥  
  21.       ﹤td width="100" bgcolor="FEFBF4" height="41"﹥序號﹤/td﹥  
  22.       ﹤td width="200" bgcolor="FEFBF4" height="41"﹥圖示名稱﹤/td﹥  
  23.       ﹤td width="100" bgcolor="FEFBF4" height="41"﹥圖書作者﹤/td﹥  
  24.       ﹤td width="200" bgcolor="FEFBF4" height="41"﹥出版社﹤/td﹥  
  25.       ﹤td width="50" bgcolor="FEFBF4" height="41"﹥圖書價格﹤/td﹥  
  26.       ﹤td width="100" bgcolor="FEFBF4" height="41"﹥操作﹤/td﹥  
  27.     ﹤/tr﹥  
  28.     ﹤!--這里使用標簽技術(shù),如果不用,就麻煩了,相信您一定有感觸--﹥  
  29.    ﹤MyBookTag:ListBook﹥  
  30.     ﹤tr align="center"﹥  
  31.       ﹤td width="100" height="19"﹥$_SerialNo﹤/td﹥  
  32.       ﹤td width="200" height="19"﹥$_BookName﹤/td﹥  
  33.       ﹤td width="100"﹥$_Author﹤/td﹥  
  34.       ﹤td width="200"﹥$_PHouse﹤/td﹥  
  35.       ﹤td width="50" height="19"﹥$_Price﹤/td﹥  
  36.       ﹤td width="100" height="19" align="left"﹥  
  37.       ﹤a href="bookEditTable.jsp?ItemNo=$_index"﹥  
  38.         ﹤font color="#0000CC"﹥編輯﹤/font﹥  
  39.       ﹤/a﹥  
  40.       |﹤a href="bookview.jsp?ItemNo=$_index"﹥  
  41.         ﹤font color="#FF0000"﹥查看﹤/font﹥  
  42.       ﹤/a﹥  
  43.       ﹤/td﹥  
  44.     ﹤/tr﹥  
  45.    ﹤/MyBookTag:ListBook﹥  
  46.  
  47. ﹤/table﹥  
  48. ﹤table width="400" border="0"﹥  
  49.     ﹤tr﹥  
  50.       ﹤td width="100%" align="right"﹥  
  51.         ﹤div align="right"﹥  
  52.           ﹤input type="submit" name="Submit" value="返回" onClick="javascript:returnBack();" class="annew1"﹥  
  53.         ﹤/div﹥  
  54.       ﹤/td﹥  
  55.     ﹤/tr﹥  
  56. ﹤/table﹥  
  57. ﹤/form﹥  
  58. ﹤p align="left"﹥ ﹤/p﹥  
  59. ﹤/body﹥  
  60. ﹤/html﹥  

以上就是頁面與代碼分離在JSP源碼中的實現(xiàn),希望對你有幫助。

【編輯推薦】

  1. JSP教程基礎(chǔ)篇之HTML表單演示
  2. JSP教程基礎(chǔ)篇之簡單首頁制作
  3. 實現(xiàn)JSP論壇樹型結(jié)構(gòu)的具體算法
  4. JSP入門之避免Form表單重復提交的幾種方案
  5. JSP入門需要知道的五個方面
責任編輯:仲衡 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2009-06-25 14:05:01

JavaBean實現(xiàn)J

2009-07-06 18:23:56

Struts和JSPJSP頁面

2009-06-30 10:37:56

JSP教程

2009-07-02 13:36:24

動態(tài)頁面JSP技術(shù)

2009-07-01 18:08:18

JSP頁面跳轉(zhuǎn)

2009-07-14 15:42:38

MyEclipse開發(fā)

2009-07-14 16:25:04

MyEclipse開發(fā)

2009-07-14 16:07:46

MyEclipse開發(fā)

2009-07-03 14:41:03

2009-07-03 18:12:49

JSP頁面

2009-07-03 11:07:37

JSP Web開發(fā)

2009-07-06 09:34:19

JSP頁面

2009-07-01 18:50:29

Dreamweaver

2009-07-02 09:56:24

導入事件驅(qū)動技術(shù)JSP Servlet

2009-07-06 10:00:31

JSP頁面?zhèn)髦?/a>

2009-07-06 15:55:50

2009-08-04 17:00:16

ASP.NET代碼分離

2009-07-01 15:13:10

JSP留言板

2010-08-06 10:49:16

FlexJsp

2009-06-30 17:01:27

訪問量JSP教程
點贊
收藏

51CTO技術(shù)棧公眾號