因此,我与一位同事讨论了为什么和在何处使用Page.ResolveUrl("~/PageUrl.aspx")而不是./PageUrl.aspx。
例如,在以下方面是否有任何区别:
<a href='<%= Page.ResolveUrl("~/Home.aspx")%>' runat="server"> Home </a>
和
<a href="./Home.aspx" runat="server"> Home </a>?
这里是我在msdn上发现的,但我从中看到的唯一好处是,Page.ResolveUrl擅长于解析内容的urls (图像&类似的东西)。
这里,您可以找到一个很好的例子,说明为什么要使用Page.ResolveUrl,但是Babu并没有提到./的使用。
对于基本的Page.ResolveUrl方法,./还有其他的好处吗?
发布于 2015-03-17 14:42:55
假设您已经创建了一个用户控件,您将在许多不同的页面上使用该控件。用户控件的一部分是指向主页的链接。
如果您在一个深度超过一个层次的页面上使用用户控件:即http://website/folder1/APageWithUserControlOn.aspx
然后是这个:
<a href="./Home.aspx" runat="server"> Home </a>
将解析为http://website/folder1/Home.aspx
如下所示:
<a href="<%= Page.ResolveUrl("~/Home.aspx")%>" runat="server">将解决http://website/home.aspx,这是更有可能是你想要的,因为链接将是正确的任何网页。当使用'~‘时,服务器端Page.Resolve从根解析url。在第一个示例中,您可以使用'/Home.aspx‘,但是在使用虚拟目录时,这并不像预期的那样工作。
https://softwareengineering.stackexchange.com/questions/276539
复制相似问题