jsp引用css文件

转载:http://javatechnology.iteye.com/blog/577469

当在命名空间下转发到相应页面时,引用外部css文件无效的解决方式:

使用Web工程的绝对路径。

例:工程路径如下:


uerMain.jsp在根目录下引用myCss.css没问题, <link rel="stylesheet"  type="text/css"  href="myCss.css"/>。

userMain.jsp下的action映射到user空间下,根据结果转发到useradd.jsp页面,此时在useradd.jsp页面引用myCss.css的方式为<link rel="stylesheet"  type="text/css"  href="/sshlogin/myCss.css"/>.

//

jsp或html页面引用外部.css或.js文件时,注意路径问题,如果设置不当,会引用不到这些外部的文件
假设使用下面的目录结构:
-webapp 
|-MyProject  目录 
 |--WebContent 目录
  |---scripts 目录
   ---dtree.js 文件
  |---styles 目录
   ---main.css 文件 
  |---pages 目录

   ---test.jsp 文件

 

现在例如要在test.jsp中引用scripts目录下的dtree.js和styles目录下的main.css

 

有如下几种方法:

 

 

 

1.使用相对于jsp页面的相对路径

Html代码  收藏代码
  1. <link type="text/css" rel="stylesheet" href="../styles/main.css" />  
  2. <script type="text/javascript" src="../scripts/dtree.js"></script>  

  

这样在页面使用http://localhost:8080/MyProject/test.jsp访问test.jsp时就可以引用到dtree.js和main.css。

 

2.使用相对于Web工程的相对路径

对于1中的相对使用相对于于jsp页面的相对路径的这种方式,如果我们是设置action跳转到test.jsp页面,那么这种使用相对路径的方式就引用不到了。
例如我们当访问http://localhost:8080/MyProject/main.do的时候,页面跳转到test.jsp页面,如果使用方法1,就引用不到了。
这个时候我们可以使用相对于Web工程的相对路径来引用:

Html代码  收藏代码
  1. <link type="text/css" rel="stylesheet" href="styles/main.css" />  
  2. <script type="text/javascript" src="scripts/dtree.js"></script>  

 

但是请注意:使用方法2这种方式引用,如果直接访问http://localhost:8080/MyProject/test.jsp,是引用不到的。

 

3.使用Web工程的绝对路径

方法1和方法2都有缺点,都只适用一种情况,有没有两种情况都适用的呢?答案肯定的!
我们使用绝对路径:

Html代码  收藏代码
  1. <link type="text/css" rel="stylesheet" href="/MyProject/styles/main.css" />  
  2. <script type="text/javascript" src="/MyProject/scripts/dtree.js"></script>  

 

这样,不管是通过http://localhost:8080/MyProject/main.do跳转访问test.jsp还是直接访问http://localhost:8080/MyProject/test.jsp,都可以成功引用。

 

注意:如果我们在部署Web应用时,没有设置Context Root(一般情况下配置为工程名),也就是IP和端口后面不带应用名,如http://localhost:8080/main.dohttp://localhost:8080/test.jsp,这种情况在引用时就不能带工程名了,应该这样:

Html代码  收藏代码
  1. <link type="text/css" rel="stylesheet" href="/styles/main.css" />  
  2. <script type="text/javascript" src="/scripts/dtree.js"></script> 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值