900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > asp.net中涉及子文件夹的母版页和相对路径文件引用问题(一)

asp.net中涉及子文件夹的母版页和相对路径文件引用问题(一)

时间:2021-10-05 05:11:12

相关推荐

asp.net中涉及子文件夹的母版页和相对路径文件引用问题(一)

母版页是如何处理相对路径的?如果你使用的是静态文字,这一问题不会困扰你。不过,如果你加入了html标记的<img>标签或者指向其他资源的HTML标签,并且这个文件与母版页不在同一文件夹下面,问题就可能发生。

当你把母版页和内容页放在不同的目录时,问题就发生了。把母版页和内容页分放到不同的目录,这是大型网站推荐使用的最佳实践。实际上,微软建议你在专门的文件夹里保存所有的母版页。不过,如果你不够小心,使用相对路径时会带来问题。

例如,假设你把母版页放在一个叫做MasterPages的子文件夹里,并在母版页里加入了如下的<img>标签:

<img src="a.jpg" />

假设文件/MasterPages/a.jpg存在,这看起来是行得通的。在Visual Studio设计环境也会出现图片。但是,如果你在另一个子文件夹里创建了一个内容页,路径就会被解释成相对于那个文件夹。如果a.jpg文件在那个子文件夹不存在,就会得到 一个破损的链接而看不到图片。更糟的是,如果有一幅具有相同文件名的另外一个图片,你会不经意地得到一幅错误的图片。

这样的问题之所以会发生,是因为<img>标签是普通的HTML。所以,不会接触到它。遗憾的是,当创建内容页的时候,这个标签就不合适了。相同的问题出现在向其他页面提供相对链接的<a>标签以及用来把母版页链接到样式表的<link>元素。

要解决这一问题,你可以预先把URL写成相对于内容页面的地址。不过这会带来混淆,限制母版页使用的范围,并且产生在设计环境里不正确显示母版页的负面效应。

另一个快捷的解决方案是把图片标签变成服务器端控件,这样就会修复这个错误:

<img src="a.jpg" runat="server" />

这个解决办法会起作用是因为根据这一信息创建一个HtmlImage服务器控件。这个对象在母版页的Page对象实例化后创建,此时,把所有路径解释为相对于母版页的位置。你可以使用同样的技术来修复<a>标签对其他页面的链接。

你还可以使用根路径语法,并用"~"字符作为URL的开头。例如,下面这个<img>标签毫无歧义地指向网站的根目录下MasterPages文件夹中的a.jpg文件。

<img src="~/MasterPages/a.jpg" runat="server" />

遗憾的是,这种语法只对服务器端控件有效。如果你要对普通的HTML产生同样的效果,你需要在链接里包含域名的完整的相对路径。这样的HTML代码难看且不可移植,所以不推荐使用。

此外当然你也可以直接利用image或者hyperlink控件来调整,不过对于其他的文件引用,我们还是需要考虑这个问题。

另一个问题,在母版页引入jquery的文件,按照上面的解决方法写成

<script src="js/jquery.js" type="text/javascript" runat="server"></script>

可是在运行的时候却出错了,说是jquery.js中的第12行的$符号不知道是什么意思,然后我把runat="server"去掉后就又运行成功了, 看来是不能加runat="server"这个属性了,可是这样的话在另一文件夹中套用母版页的时候又会出现上面这个相对路径的错误了,经到CSDN论坛发贴问,解决方法如下:

<script src='<%=ResolveUrl("~/js/jquery.js") %>' type="text/javascript"></script>

/tut/69685.html

.net绝对路径和相对路径的问题

。aspx页面可以这样引用asax

<%@ register src="~/UserControls/xxx.ascx" tagname="myuc" tagprefix="uc1" %>

~/ 的意思是相对站点的虚拟根路径

对于.asax内部的如图片、连接等:

如果是Web空件如,HyperLink,Image,路径设置同上:

<asp:hyperlink navigatorurl="~/yourfolder/yourpage.aspx" runat = server />

如果是静态HMTL的如<a/> <img/>等标记:

方法1:

加上runat=server使之成为HTML服务器控件:

<img src="~/images/myimg.gif"/>

方法2:动态过程绝对路径

<img src="<% =HttpContext.Current.Request.ApplicationPath %>/images/myimg.gif">

记住 ~/ 仅对 的服务器控件起作用就可以了。

1."<% =HttpContext.Current.Request.ApplicationPath %>/

2.HttpContext.Current.Request.Url.GetLeftPart(UriPartial.Authority)

3.runat=server

以下会出现URL混乱:

1 母版页MainMaster.master和内容页1.aspx, 2.aspx 位于不同的子文件夹(MasterPages,Folder1, Folder2)

2 母版页用到用户控件Menu.ascx

3 用户控件Menu.ascx中有HyperLink1,使用 ~/Folder1/1.aspx; HyperLink2,使用 ~/Folder2/2.aspx

4 缓存用户控件Menu.ascx

if ($ != jQuery) { $ = jQuery.noConflict(); }

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。