主頁 > 知識庫 > 使用jsp:include控制動態(tài)內(nèi)容的方法

使用jsp:include控制動態(tài)內(nèi)容的方法

熱門標簽:如何用中國地圖標注數(shù)字點 好操作的電話機器人廠家 泰州泰興400電話 怎么申請 地圖標注市場怎么樣 聊城智能電銷機器人外呼 南京新思維電話機器人 南昌市地圖標注app 企業(yè)怎么在聯(lián)通申請400電話 百度地圖添加標注圖標樣式

本文實例講述了使用jsp:include控制動態(tài)內(nèi)容的方法。分享給大家供大家參考,具體如下:

清單 1. JSP include 偽指令

![CDATA[
%@ page language="java" contentType="text/html" %>
html>
head>
title>newInstance.com/title>
meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
link href="/styles/default.css" rel="stylesheet" type="text/css" />
/head>
body>
%@ include file="header.jsp" %>
%@ include file="navigation.jsp" %>
%@ include file="bookshelf.jsp" %>
%@ include file="/mt-blogs/index.jsp" %>
%@ include file="footer.jsp" %>
/body>
/html>
]]>

雖然 include 非常適于將靜態(tài)內(nèi)容并入 Web 頁面,但對于動態(tài)內(nèi)容卻不盡如人意。我們在前一篇文章中在試圖重新裝入高速緩存文件時發(fā)現(xiàn)了這一問題。與大多數(shù)頁眉文件及頁腳文件不同,動態(tài)內(nèi)容變化頻繁,必須時刻更新。我們將首先扼要地重述一下 include 偽指令的局限性,然后我將向您演示如何用 jsp:include 標記來擴展 JSP 的包含能力。

高速緩存問題

JSP include 偽指令的不足之處有一個是:它會導致 Web 瀏覽器高速緩存所有頁面。在處理諸如頁腳、版權(quán)聲明或一組靜態(tài)鏈接之類的靜態(tài)組件時,這是有意義的。這些文件不會改變,因此沒有理由讓 JSP 解釋器不斷地重新輪詢其中的數(shù)據(jù)。凡是可能的地方,都應該實現(xiàn)高速緩存,因為它改善了應用程序的性能。

但是,有時侯,進行高速緩存會得不償失。如果提入的內(nèi)容來自使用動態(tài)數(shù)據(jù)(如 Weblog 或數(shù)據(jù)庫驅(qū)動的 JSP 文件)的程序,甚至如果所包含的內(nèi)容是經(jīng)常變化的 HTML(如時間戳記),那么每當裝入 Web 頁面時,都需要顯示這些文件或程序的最新版本。遺憾的是,JSP include 偽指令并不具備這一功能。在測試和開發(fā)周期(請參閱側(cè)欄“ JSP 測試和開發(fā)”)中,在瀏覽器中禁用高速緩存通常能夠解決這一問題。但是,對于實際使用的應用程序而言,性能是任何設計決策過程中的一項重要因素,禁用高速緩存并不是一種可行的長遠之計。更好的解決方案是使用 jsp:include 標記。

jsp:include 標記

jsp:include 只不過是一個不同于 include 的偽指令而已。 jsp:include 的優(yōu)點在于:它 總是會檢查所含文件中的變化。過一會兒我們將研究這一新標記的工作方式。但首先看一下兩種 include 各自的代碼,以便能夠看到二者之間的異同。

清單 2 顯示了一個簡單頁面,它使用了原始的 JSP include 偽指令。

清單 2. JSP include 偽指令

![CDATA[
%@ page language="java" contentType="text/html" %>
html>
head>
title>JSP include element test/title>
/head>
body>
This content is statically in the main JSP file.br />
%@ include file="included.html" %>
/body>
/html>
]]>

清單 3 是同一個頁面,只不過這里轉(zhuǎn)成使用 jsp:include 標記。

清單 3. 轉(zhuǎn)成使用 jsp:include

![CDATA[
%@ page language="java" contentType="text/html" %>
html>
head>
title>JSP include element test/title>
/head>
body>
This content is statically in the main JSP file.br />
jsp:include page="included.html" flush="true" />
/body>
/html>
]]>

您應該注意這兩種代碼類型之間的兩大區(qū)別。首先, jsp:include 元素不使用屬于 include 偽指令的 %@ 語法。實際上, jsp 前綴讓 JSP 編譯器知道:它應該尋找標準 JSP 標記集中的元素。其次,指定要包含的文件的屬性從 file 變成了 page 。如果愿意,可以自己測試一下新標記的結(jié)果。只需更改上一篇文章(請參閱 參考資料)中 included.html 文件的內(nèi)容,然后重新裝入瀏覽器頁面,就會立即看到新內(nèi)容。

jsp:include 是如何工作的

如果您有點愛刨根問底,那么可能十分想知道 jsp:include 標記的行為為什么與 include 偽指令不同。道理其實十分簡單: jsp:include 包含的是所包含 URI 的 響應,而不是 URI 本身。這意味著:對所指出的 URI 進行 解釋,因而包含的是 生成的響應。如果頁面是 HTML,那么將得到一點也沒有變化的 HTML。但是,如果是 Perl 腳本、Java servlet 或者 CGI 程序,那么得到的將是從該程序解釋而得的結(jié)果。雖然頁面通常就是 HTML,但實際程序恰好是達到目的的手段。而且,由于每次請求頁面的時候都會進行解釋,因此從來不會象使用 include 偽指令時那樣高速緩存結(jié)果。雖然這只是很小的變動,但它卻導致了您所見到的行為中的全部差異。

一種混合搭配的解決方案

include 偽指令在某些網(wǎng)站上有其用武之地。例如,如果站點包含一些(如果有變化,也很少)幾乎沒有變化的頁眉、頁腳和導航文件,那么基本的 include 偽指令是這些組件的最佳選項。由于 include 偽指令采用了高速緩存,因此只需放入包含文件一次,其內(nèi)容就會被高速緩存,其結(jié)果會是極大地提高了站點的性能。

然而,對于現(xiàn)在許多 Web 應用程序或站點而言,地毯式的高速緩存并不能解決問題。雖然頁眉和頁腳可能是靜態(tài)的,但是不可能整個站點都是靜態(tài)的。例如,從數(shù)據(jù)庫提取導航鏈接是很常見的,并且許多基于 JSP 技術(shù)的站點還從其它站點或應用程序上的動態(tài) JSP 頁面提取內(nèi)容。如果正在處理動態(tài)內(nèi)容,那么需要采用 jsp:include 來處理該內(nèi)容。

當然,最好的解決方案是經(jīng)常把這兩種方法混合搭配使用,將每種構(gòu)造用到最恰當?shù)牡胤健G鍐?4 是混合搭配包含解決方案的一個示例。

清單 4. 混合搭配解決方案

![CDATA[
%@ page language="java" contentType="text/html" %>
html>
head>
title>newInstance.com/title>
meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
link href="/styles/default.css" rel="stylesheet" type="text/css" />
/head>
body>
jsp:include page="header.jsp" flush="true">
jsp:param name="pageTitle" value="newInstance.com"/>
jsp:param name="pageSlogan" value=" " />/jsp:include>
%@ include file="/navigation.jsp" %>
jsp:include page="bookshelf.jsp" flush="true" />
jsp:include page="/mt-blogs/index.jsp" flush="true" />
%@ include file="/footer.jsp" %>
/body>
/html>
]]>

上面的代碼顯示了前面文章中的示例索引頁面。導航鏈接和頁腳是靜態(tài)內(nèi)容,一年最多更改一次。對于這些文件,我使用了 include 偽指令。內(nèi)容窗格包含 Weblog 和“bookshelf”組件,它們是動態(tài)生成的。這兩個組件需要一直更新,因此對它們,我使用了 jsp:include 標記。 header.jsp 文件有點奇怪。這個組件是從另一個本質(zhì)上是靜態(tài)的 JSP 頁面提取的。但是,正如您將注意到的那樣,它從包含頁提取頁“標語”,然后將它顯示出來。要處理這一共享信息,我們必須向頁眉文件傳入?yún)?shù)。而要處理那些參數(shù),就必須使用 jsp:include 元素。

希望本文所述對大家jsp程序設計有所幫助。

您可能感興趣的文章:
  • JSP常見的三個編譯指令page、include、taglib
  • JSP中的include有幾種形式?都有什么區(qū)別?
  • jsp中include指令靜態(tài)導入和動態(tài)導入的區(qū)別詳解
  • JSP編譯指令page、include詳解
  • JSP中動態(tài)include與靜態(tài)include的區(qū)別介紹
  • JSP指令元素(page指令/include指令/taglib指令)復習整理
  • 基于jsp:included的使用與jsp:param亂碼的解決方法
  • jsp include引用非本級目錄網(wǎng)頁實現(xiàn)代碼
  • jsp include文件時的一個亂碼解決方法
  • JSP中include指令和include行為的區(qū)別
  • JSP下動態(tài)INCLUDE與靜態(tài)INCLUDE的區(qū)別分析

標簽:山南 銅川 吉林 白銀 臨汾 烏蘭察布 自貢 開封

巨人網(wǎng)絡通訊聲明:本文標題《使用jsp:include控制動態(tài)內(nèi)容的方法》,本文關(guān)鍵詞  使用,jsp,include,控制,動態(tài),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用jsp:include控制動態(tài)內(nèi)容的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用jsp:include控制動態(tài)內(nèi)容的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章