绝对路径和相对路径---速记

复习回顾基础知识时看到了绝对路径和相对路径的问题,仔细想想对此概念有些模糊,查阅资料后,马上记录下来,并分享与各位。


=======================================================================================================


一、基本概念

  1、相对路径-顾名思义,相对路径就是相对于当前文件的路径。网页中一般表示路径使用这个方法。

2、绝对路径-绝对路径就是你的主页上的文件或目录在硬盘上真正的路径。绝对路径就是你的主页上的文件或目录在硬盘上真正的路径,比如,你的Perl 程序是存放在 c:/apache/cgi-bin 下的,那么 c:/apache/cgi-bin就是cgi-bin目录的绝对路径

在网络中,以http开头的链接都是绝对路径,绝对路径就是你的主页上的文件或目录在硬盘上真正的路径,绝对路径一般在CGI程序的路径配置中经常用到,而在制作网页中实际很少用到。

二、相对路径使用的特殊符号

以下为建立路径所使用的几个特殊符号,及其所代表的意义。

"./":代表目前所在的目录。

"../":代表上一层目录。

以"/"开头:代表根目录。

 

根目录下有Site1和Image/Image.jpg,Site1下有Page1.html文件和Site2文件夹。Site2下有Page2.html和Page2Image.jpg图片文件。

1、文件在当前目录

         Page2.html访问Page2Image.jpg

         <img src=”./Page2Image.jpg”>或者<img src=”Page2Image. jpg”>

   2、文件在上一层目录

              Page1.html访问Image下的Image.jpg

              <img src=”../Image/Image.jpg”>

              Page2.html访问Image下的Image.jpg

              <img src=”../../Image/Image.jpg”>

3、文件在下一层目录

         Page1.html访问Site2文件夹下的Page2Image.jpg

              <img src=” ./Site2/Image.jpg”><img src=” Site2/Image.jpg”>

 4、根目录表示法,任何页面访问Image下的Image.jpg图片

              <img src=”/Image/Image.jpg”>

三、常使用且要注意的地方

A、Css中的图片路径。写css里的图片路径,url是图片针对样式文件的位置

-- index.html

-- css   /main.css

-- images/1.jpg

如果: index.html引用main.css,且在main.css 引用images目录里的1.jpg :

      background: url(../images/1.jpg)  *** 正确

background: url(images/1.jpg)    *** 错误

B、Js中图片地址均相对于调用JS的页面的相对位置。

document.getElementById("IMG1").style.backgroundImage

= "url(../Images/login.jpg)";

四、优缺点及使用的地方

1、绝对路径的优点

    A、如果有人抄袭你的网站内容,里面的链接还会指向你的网站,有些抄袭的人比较懒,根本不会去改内容。其实也不局限于被抄袭,如果有人将你的网页保存到本地电脑中,里面的链接、图片、css、以及js仍然会连接到你的网站。

    B、如果网页位置改变,里面的链接还是指向正确的URL。

2、绝对路径的缺点:

    A、在编码编写时不方便使用绝对路径,因为链接应该指向真正的域名而不是开发站点。


相对路径的优缺点和绝对路径几乎相反。

3、相对路径的优点:

    A、容易移动内容,可以整个目录移动。

    B、测试方法比较灵活,本机测试时比较方便。

4、相对路径的缺点:

    A、部分内容页面换了位置时,链接容易失效。

    B、容易被人大面积采集抄袭。


五、关于JSP/Servlet中的相对路径和绝对路径。

5.1、服务器端的地址

   服务器端的相对地址指的是相对于你的web应用的地址,这个地址是在服务器端解析的
(不同于html和javascript中的相对地址,他们是由客户端浏览器解析的)也就是说这时候
在jsp和servlet中的相对地址应该是相对于你的web应用,即相对于http://192.168.0.1/webapp/的。

  其用到的地方有: 
 forward:servlet中的request.getRequestDispatcher(address);这个address是
在服务器端解析的,所以,你要forward到a.jsp应该这么写:
request.getRequestDispatcher(“/user/a.jsp”)这个/相对于当前的web应用webapp,
其绝对地址就是:http://192.168.0.1/webapp/user/a.jsp。 
sendRedirect:在jsp中<%response.sendRedirect("/rtccp/user/a.jsp");%>

5.2、客户端的地址 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值