簡介:本文是 Java Brett McLaughlin 繼第一篇 JSP 最佳實踐文章後的後續文章,在文中,作者向 您演示了如何擴展 JSP 技術中用於動態內容的包含功能。了解靜態 include 偽指令和動態 jsp:include 元素之間的差異,搞清楚如何混合搭配這二者以獲取最優性能。
在新的 JSP 最佳實踐系列的前一篇文章中,您了解了如何使用 JSP include 偽指令將諸如頁眉、頁 腳和導航組件之類的靜態內容包含到 Web 頁面中。和服務器端包含一樣,JSP include 偽指令允許某個 頁面從另一個頁面提取內容或數據。清單 1 重溫了 include 偽指令。
清單 1. JSP include 偽指令
<%@ 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 非常適於將靜態內容並入 Web 頁面,但對於動態內容卻不盡如人意。我們在前一篇文 章中在試圖重新裝入高速緩存文件時發現了這一問題。與大多數頁眉文件及頁腳文件不同,動態內容變化 頻繁,必須時刻更新。我們將首先扼要地重述一下 include 偽指令的局限性,然後我將向您演示如何用 jsp:include 標記來擴展 JSP 的包含能力。
高速緩存問題
JSP include 偽指令的不足之處有一個是:它會導致 Web 浏覽器高速緩存所有頁面。在處理諸如頁腳 、版權聲明或一組靜態鏈接之類的靜態組件時,這是有意義的。這些文件不會改變,因此沒有理由讓 JSP 解釋器不斷地重新輪詢其中的數據。凡是可能的地方,都應該實現高速緩存,因為它改善了應用程序的性 能。
但是,有時侯,進行高速緩存會得不償失。如果提入的內容來自使用動態數據(如 Weblog 或數據庫 驅動的 JSP 文件)的程序,甚至如果所包含的內容是經常變化的 HTML(如時間戳記),那麼每當裝入 Web 頁面時,都需要顯示這些文件或程序的最新版本。遺憾的是,JSP include 偽指令並不具備這一功能 。在測試和開發周期(請參閱側欄“ JSP 測試和開發”)中,在浏覽器中禁用高速緩存通常能夠解決這 一問題。但是,對於實際使用的應用程序而言,性能是任何設計決策過程中的一項重要因素,禁用高速緩 存並不是一種可行的長遠之計。更好的解決方案是使用 jsp:include 標記。