日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
JSP源碼技術(shù)之頁面與代碼分離

在傳統(tǒng)的JSP源碼程序中,頁面與代碼分離還不是很普遍的應(yīng)用我們將HTML代碼與Java代碼混合在一起編寫,這樣雖然方便,但同時也導(dǎo)致頁面難以維護,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. }

二、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﹥

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

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

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

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


新聞名稱:JSP源碼技術(shù)之頁面與代碼分離
網(wǎng)頁URL:http://www.dlmjj.cn/article/cojgjcp.html