關(guān)于include標(biāo)簽導(dǎo)致js路徑找不到的問題分析及解決
先回憶一下二者的區(qū)別(對(duì)于此篇文章而言,二者在用法上沒有區(qū)別)
jsp:include是先編譯一下included.jsp文件,然后再包含(先編譯,后包含)
@ include是先把文件包含就來,然后統(tǒng)一編譯(先包含,后編譯)
今天下午想把Jquery集成到項(xiàng)目中,發(fā)現(xiàn)怎么樣都會(huì)出問題。原因就是路徑問題。
在集成時(shí),我的思路是寫一個(gè)公共JSP文件,里面包含一些常用的js文件,當(dāng)然此處我用的就是Jquery插件了。
但寫完發(fā)現(xiàn)單獨(dú)測(cè)試公共JSP是可以使用的,但包含公共JSP頁(yè)面的頁(yè)面卻始終不能使用JQuery,開始還以為是加載順序的問題。
幾經(jīng)測(cè)試,終于發(fā)現(xiàn)了其中的問題。
由于做的項(xiàng)目文件較多,故文件都不放在一個(gè)文件夾下:在公共JSP頁(yè)面中,有
<%@ 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)用它的時(shí)候,有:
<%@ include file="../../common_ext.jsp"%>
但這樣很可能導(dǎo)致錯(cuò)誤。
原因是,include之后,公共JSP被加載到自己的JSP,則JQueryr的相對(duì)位置已經(jīng)發(fā)生了變化。即公共JSP把JQuery的相對(duì)位置傳給了自己的JSP,但自己的JSP以自身為標(biāo)準(zhǔn),通過路徑就找不到Jquery插件了。簡(jiǎn)單地說,就是如果用相對(duì)路徑,則公共JSP中的路徑就應(yīng)該是相對(duì)自己jSP的路徑了。
但這樣顯然失去了它是公共JSP的意義,因此在這里用絕對(duì)路徑來做:
<%@ 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頁(yè)面中引入公共JSP就可以了。
相關(guān)文章
微信小程序?qū)崿F(xiàn)計(jì)時(shí)器開始和結(jié)束功能
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)計(jì)時(shí)器開始和結(jié)束功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07BootStrap 動(dòng)態(tài)添加驗(yàn)證項(xiàng)和取消驗(yàn)證項(xiàng)的實(shí)現(xiàn)方法
這篇文章主要介紹了BootStrap 動(dòng)態(tài)添加驗(yàn)證項(xiàng)和取消驗(yàn)證項(xiàng)的實(shí)現(xiàn)方法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09JS消息彈框alert、confirm、prompt的實(shí)現(xiàn)代碼
這篇文章主要介紹了JS消息彈框alert、confirm、prompt,文中還給大家介紹了js的三大基礎(chǔ)彈框,結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09ComboBox(下拉列表框)通過url加載調(diào)用遠(yuǎn)程數(shù)據(jù)的方法
這篇文章主要介紹了ComboBox(下拉列表框)通過url加載調(diào)用遠(yuǎn)程數(shù)據(jù)的方法 ,需要的朋友可以參考下2017-08-08Bootstrap 模態(tài)對(duì)話框只加載一次 remote 數(shù)據(jù)的完美解決辦法
前端框架 Bootstrap 的模態(tài)對(duì)話框,可以使用 remote 選項(xiàng)指定一個(gè) URL,這樣對(duì)話框在第一次彈出的時(shí)候就會(huì)自動(dòng)從這個(gè)地址加載數(shù)據(jù)到 .modal-body 中,但是它只會(huì)加載一次,不過通過在事件中調(diào)用 removeData() 方法可以解決這個(gè)問題,具體操作方法,大家通過本文了解下吧2017-07-07echarts數(shù)據(jù)可視化實(shí)現(xiàn)多個(gè)柱狀堆疊圖頂部顯示總數(shù)示例
這篇文章主要為大家介紹了echarts實(shí)現(xiàn)多個(gè)柱狀堆疊圖頂部顯示總數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07