首页 > 代码库 > web中src引用文件的路径问题

web中src引用文件的路径问题

在编写web应用的时候,难免会在一个文件中引用外部的文件,例如样式表css文件以及一些脚本js文件,这样做的目的无疑是提高代码的复用率。但是在引用文件时,一定要引用正确的文件路径,不然是访问不到相关文件的。

总结一下,一共有如下几种方式引用相关文件:

前提:

相关目录结构:

技术分享

技术分享

方法一:使用相对于当前文件(源文件)的相对路径

 

[html] view plain copy print?
  1. <link type="text/css" rel="stylesheet" href=http://www.mamicode.com/"../styles/main.css" />    
  2. <script type="text/javascript" src=http://www.mamicode.com/"../scripts/dtree.js"></script>    
<link type="text/css" rel="stylesheet" href="http://www.mamicode.com/styles/main.css" />  
<script type="text/javascript" src="http://www.mamicode.com/scripts/dtree.js"></script>  

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

 

方法二:使用相对于web工程的相对路径

 

[html] view plain copy print?
  1. <link type="text/css" rel="stylesheet" href=http://www.mamicode.com/"styles/main.css" />    
  2. <script type="text/javascript" src=http://www.mamicode.com/"scripts/dtree.js"></script>    
<link type="text/css" rel="stylesheet" href="http://www.mamicode.com/styles/main.css" />  
<script type="text/javascript" src="http://www.mamicode.com/scripts/dtree.js"></script>  

但是如上两种方法都有其瓶颈,对于方法一中的相对使用相对于于jsp页面的相对路径的这种方式,如果我们是设置action跳转到test.jsp页面,那么这种使用相对路径的方式就引用不到了。例如我们当访问http://localhost:8080/MyProject/main.do的时候,页面跳转到test.jsp页面,如果使用方法1,就引用不到了。如果使用方法2这种方式引用,如果直接访问http://localhost:8080/MyProject/test.jsp,是引用不到的。

 

那么有没有一种两全其美的方法呢,答案是肯定的,也就是我们的方法三:使用web工程的绝对路径

 

[html] view plain copy print?
  1. <link type="text/css" rel="stylesheet" href=http://www.mamicode.com/"/MyProject/styles/main.css" />    
  2. <script type="text/javascript" src=http://www.mamicode.com/"/MyProject/scripts/dtree.js"></script>    
<link type="text/css" rel="stylesheet" href="http://www.mamicode.com/MyProject/styles/main.css" />  
<script type="text/javascript" src="http://www.mamicode.com/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.do和http://localhost:8080/test.jsp,这种情况在引用时就不能带工程名了,应该这样:

 

 

[html] view plain copy print?
  1. <link type="text/css" rel="stylesheet" href=http://www.mamicode.com/"/styles/main.css" />    
  2. <script type="text/javascript" src=http://www.mamicode.com/"/scripts/dtree.js"></script>    
<link type="text/css" rel="stylesheet" href="http://www.mamicode.com/styles/main.css" />  
<script type="text/javascript" src="http://www.mamicode.com/scripts/dtree.js"></script>  

web中src引用文件的路径问题