關(guān)于include標(biāo)簽導(dǎo)致js路徑找不到的問題分析及解決
更新時間:2013年07月09日 17:39:33 作者:
本文為大家詳細(xì)介紹下關(guān)于使用jsp:include標(biāo)簽及<%@ include標(biāo)簽時要注意的事項(xiàng)以及實(shí)測發(fā)現(xiàn)問題并解決問題的全過程,感興趣的各位可以參考下哈,希望對大家有所幫助
關(guān)于使用jsp:include標(biāo)簽及<%@ include標(biāo)簽時要注意的事項(xiàng)
先回憶一下二者的區(qū)別(對于此篇文章而言,二者在用法上沒有區(qū)別)
jsp:include是先編譯一下included.jsp文件,然后再包含(先編譯,后包含)
@ include是先把文件包含就來,然后統(tǒng)一編譯(先包含,后編譯)
今天下午想把Jquery集成到項(xiàng)目中,發(fā)現(xiàn)怎么樣都會出問題。原因就是路徑問題。
在集成時,我的思路是寫一個公共JSP文件,里面包含一些常用的js文件,當(dāng)然此處我用的就是Jquery插件了。
但寫完發(fā)現(xiàn)單獨(dú)測試公共JSP是可以使用的,但包含公共JSP頁面的頁面卻始終不能使用JQuery,開始還以為是加載順序的問題。
幾經(jīng)測試,終于發(fā)現(xiàn)了其中的問題。
由于做的項(xiàng)目文件較多,故文件都不放在一個文件夾下:在公共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>
在調(diào)用它的時候,有:
<%@ include file="../../common_ext.jsp"%>
但這樣很可能導(dǎo)致錯誤。
原因是,include之后,公共JSP被加載到自己的JSP,則JQueryr的相對位置已經(jīng)發(fā)生了變化。即公共JSP把JQuery的相對位置傳給了自己的JSP,但自己的JSP以自身為標(biāo)準(zhǔn),通過路徑就找不到Jquery插件了。簡單地說,就是如果用相對路徑,則公共JSP中的路徑就應(yīng)該是相對自己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就可以了。
先回憶一下二者的區(qū)別(對于此篇文章而言,二者在用法上沒有區(qū)別)
jsp:include是先編譯一下included.jsp文件,然后再包含(先編譯,后包含)
@ include是先把文件包含就來,然后統(tǒng)一編譯(先包含,后編譯)
今天下午想把Jquery集成到項(xiàng)目中,發(fā)現(xiàn)怎么樣都會出問題。原因就是路徑問題。
在集成時,我的思路是寫一個公共JSP文件,里面包含一些常用的js文件,當(dāng)然此處我用的就是Jquery插件了。
但寫完發(fā)現(xiàn)單獨(dú)測試公共JSP是可以使用的,但包含公共JSP頁面的頁面卻始終不能使用JQuery,開始還以為是加載順序的問題。
幾經(jīng)測試,終于發(fā)現(xiàn)了其中的問題。
由于做的項(xiàng)目文件較多,故文件都不放在一個文件夾下:在公共JSP頁面中,有
復(fù)制代碼 代碼如下:
<%@ 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>
在調(diào)用它的時候,有:
<%@ include file="../../common_ext.jsp"%>
但這樣很可能導(dǎo)致錯誤。
原因是,include之后,公共JSP被加載到自己的JSP,則JQueryr的相對位置已經(jīng)發(fā)生了變化。即公共JSP把JQuery的相對位置傳給了自己的JSP,但自己的JSP以自身為標(biāo)準(zhǔn),通過路徑就找不到Jquery插件了。簡單地說,就是如果用相對路徑,則公共JSP中的路徑就應(yīng)該是相對自己jSP的路徑了。
但這樣顯然失去了它是公共JSP的意義,因此在這里用絕對路徑來做:
復(fù)制代碼 代碼如下:
<%@ 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就可以了。
相關(guān)文章
JavaScript對象解構(gòu)的用法實(shí)例解析
解構(gòu)賦值允許你使用類似數(shù)組或?qū)ο笞置媪康恼Z法將數(shù)組和對象的屬性賦給各種變量,下面這篇文章主要給大家介紹了關(guān)于JavaScript對象解構(gòu)用法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01
基于JavaScript實(shí)現(xiàn)無縫滾動效果
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)無縫滾動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
JavaScript裝箱及拆箱boxing及unBoxing用法解析
這篇文章主要介紹了JavaScript裝箱及拆箱boxing及unBoxing用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06
通過action傳過來的值在option獲取進(jìn)行驗(yàn)證的方法
通過action傳過來的值在option獲取進(jìn)行驗(yàn)證,下面有個不錯的示例,需要的朋友不要錯過2013-11-11
JavaScript實(shí)現(xiàn)人體面部活體檢測的功能
本文詳細(xì)介紹了如何在瀏覽器端使用JavaScript實(shí)現(xiàn)高可靠度的人臉活體檢測,包括核心原理、可行方案、優(yōu)缺點(diǎn)對比以及示例代碼,感興趣的朋友一起看看吧2025-02-02
ES6中Class類的靜態(tài)方法實(shí)例小結(jié)
這篇文章主要介紹了ES6中Class類的靜態(tài)方法,結(jié)合實(shí)例形式簡單總結(jié)分析了ES6中class類中靜態(tài)方法的使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-10-10

