1. 程式人生 > >關於使用jsp:include標籤及

關於使用jsp:include標籤及

http://blog.csdn.net/angus_17/article/details/7878937

先回憶一下二者的區別(對於此篇文章而言,二者在用法上沒有區別)

jsp:include是先編譯一下included.jsp檔案,然後再包含        先編譯,後包含
@ include是先把檔案包含就來,然後統一編譯                   先包含,後編譯

今天下午想把Jquery整合到專案中,發現怎麼樣都會出問題。原因就是路徑問題。

在整合時,我的思路是寫一個公共JSP檔案,裡面包含一些常用的js檔案,當然此處我用的就是Jquery外掛了。

但寫完發現單獨測試公共JSP是可以使用的,但包含公共JSP頁面的頁面卻始終不能使用JQuery,開始還以為是載入順序的問題。

幾經測試,終於發現了其中的問題。

由於做的專案檔案較多,故檔案都不放在一個資料夾下:在公共JSP頁面中,有

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<script type="text/javascript" src="js/jquery132min.js"></script>

    <script type="text/javascript">    
    $(function(){
    alert('hello1');
    });
</script>

在呼叫它的時候,有:

<%@ include file="../../common_ext.jsp"%>

但這樣很可能導致錯誤。

原因是,include之後,公共JSP被載入到自己的JSP,則JQueryr的相對位置已經發生了變化。即公共JSP把JQuery的相對位置傳給了自己的JSP,但自己的JSP以自身為標準,通過路徑就找不到Jquery外掛了。簡單地說,就是如果用相對路徑,則公共JSP中的路徑就應該是相對自己jSP的路徑了。

但這樣顯然失去了它是公共JSP的意義,因此在這裡用絕對路徑來做:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<%
String tPath = request.getContextPath();
String tBasePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+tPath+"/";
%>

<script type="text/javascript" src="<%=tBasePath%>js/jquery132min.js"></script>
    <script type="text/javascript">
    
    $(function(){
    alert('hello1');
    });
    
    </script>

這樣,只要在自己的jSP頁面中引入公共JSP就可以了。