Url相对路径的问题总结
程序员文章站
2023-11-12 22:28:52
最让人担心的是,有时候必须使用绝对路径(如asp.net中的master内容),因为处于开发过程,没有目标地址,也就无法配置绝对路径。有时确必须使用相对路径。 但是相对路径...
最让人担心的是,有时候必须使用绝对路径(如asp.net中的master内容),因为处于开发过程,没有目标地址,也就无法配置绝对路径。有时确必须使用相对路径。
但是相对路径写好了,却存在各种各样的问题。
今天,我介绍大家两种不一样的方法。
首先介绍最简单的就是html5里新增的base标签。
我们看它的用法,必须包含在head标签中。
<head>
<base target="_blank" href="www.test.com" />
</head>
最重要的是,base标签配置好以后,浏览器将不再使用当前文档内的相对url,而使用指定的基本 url 来解析所有的相对 url。
看上图,如果你的<a>、<img>、<link>、<form> 标签中的url为"chamychen.jpg",那么浏览器会在链接地址时自动在此url前加上base标签中指定的href地址,其打开方式也将遵循base标签中设定的target属性。那么以后,我们可以在master,mvc可以在layout.shtml中设置base标签,来解决头疼的绝对径路和相对径路的问题。我们以后,可以把所有的相对径路,都设置成从网站根目录下开始。base中配置网址就可以,解决所有的相对路径和绝对路径的问题了。
针对不支持html5的浏览器,其实我们可以使用c#写几句代码,就可以获取网站根目录的地址了:
public static string hosturl()
{
string path = httpcontext.current.request.url.scheme + "://" +
httpcontext.current.request.url.authority +
(httpcontext.current.request.applicationpath == "/" ? "" : httpcontext.current.request.applicationpath);
return path;
}
综上所述:你只需要使用“网址+相对路径”的方式就能够处理因相对径路引发的问题。
如:http://www.test.com/ab/abc.jpg
可以使用base标签:
<head>
<base target="_blank" href="www.test.com" />
</head>
相对路径写成:<img src="ab/abc.jpg"/>
如果使用多c#来支持:则为hosturl()+"ab/abc.jpg"
但是相对路径写好了,却存在各种各样的问题。
今天,我介绍大家两种不一样的方法。
首先介绍最简单的就是html5里新增的base标签。
我们看它的用法,必须包含在head标签中。
复制代码 代码如下:
<head>
<base target="_blank" href="www.test.com" />
</head>
最重要的是,base标签配置好以后,浏览器将不再使用当前文档内的相对url,而使用指定的基本 url 来解析所有的相对 url。
看上图,如果你的<a>、<img>、<link>、<form> 标签中的url为"chamychen.jpg",那么浏览器会在链接地址时自动在此url前加上base标签中指定的href地址,其打开方式也将遵循base标签中设定的target属性。那么以后,我们可以在master,mvc可以在layout.shtml中设置base标签,来解决头疼的绝对径路和相对径路的问题。我们以后,可以把所有的相对径路,都设置成从网站根目录下开始。base中配置网址就可以,解决所有的相对路径和绝对路径的问题了。
针对不支持html5的浏览器,其实我们可以使用c#写几句代码,就可以获取网站根目录的地址了:
复制代码 代码如下:
public static string hosturl()
{
string path = httpcontext.current.request.url.scheme + "://" +
httpcontext.current.request.url.authority +
(httpcontext.current.request.applicationpath == "/" ? "" : httpcontext.current.request.applicationpath);
return path;
}
综上所述:你只需要使用“网址+相对路径”的方式就能够处理因相对径路引发的问题。
如:http://www.test.com/ab/abc.jpg
可以使用base标签:
<head>
<base target="_blank" href="www.test.com" />
</head>
相对路径写成:<img src="ab/abc.jpg"/>
如果使用多c#来支持:则为hosturl()+"ab/abc.jpg"
上一篇: C#数据结构与算法揭秘四 双向链表
下一篇: python实现五子棋小游戏