您的位置:首页 > Web前端 > CSS

jsp引用js和css路径问题

2015-07-27 16:00 543 查看
这是参照的两个网址:http://jzgl-javaeye.iteye.com/blog/658446
http://blog.sina.com.cn/s/blog_6cbe0cff0101j6jl.html 
解决方案 
1) 采用绝对路径,但为了解决不同部署方式的差别,在所有非struts标签的路径前加${pageContext.request.contextPath},如原路径为: 

”/images/title.gif”,改为 

“${pageContext.request.contextPath}/images/title.gif”。 

代码” ${pageContext.request.contextPath}”的作用是取出部署的应用程序名,这样不管如何部署,所用路径都是正确的。 

缺点: 

操作不便,其他工具无法正确解释${pageContext.request.contextPath} 
2)  采用相对路径,在每个JSP文件中加入base标签,如:(没有用过) 

<base href="http://${header['host']}${pageContext.request.contextPath}/pages/cust/relation.jsp" /> 

这样所有的路径都可以使用相对路径。 

缺点: 

对于被包含的文件依然无效。 

    真正使用时需要灵活应用1)和2),写出更加健壮的代码。 

在使用的时候可以使用${pageContext.request.contextPath},也同时可以使用<%=request.getContextPath()%>达到同样的效果,同时,也可以将${pageContext.request.contextPath},放入一个JSP文件中,将用C:set放入一个变量中,然后在用的时候用EL表达式取出来

 

3)  这是用来获取根目录的路径  一般在做超连接的时候用这个 还有就是在做删除文件的时候使用 使用它的好处是为了防止路径错位

<%

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

path : /jspSmartUpLoad

basePath :http://yangm1203.oicp.net:8080/jspSmartUpLoad/

request.getScheme() : http

request.getServerName() : yangm1203.oicp.net

request.getServerPort() : 8080

 通过jsp的表达式引用(推荐:应为是原生的)

<li><a href="<%=path%>/index.jsp" >首页</a></li>
<li><a href="<%=path%>/info/index.jsp">关于我们</a></li>

通过el来引用

在页面中应用(EL表达式) ${path}/images/xx.jpg(绝对定位:oa/images/xx.jpg)

4)jstl标签

<link rel="stylesheet" href="<c:url value='/js/jqwidgets/styles/jqx.custom.css'/>" type="text/css"/>

<script type="text/javascript" src="<c:url value='/js/jquery/jquery-1.7.2.js'/>" ></script>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: