I have an ASP.NET application that uses themes. Let’s pretend I have a theme named “MySkin”.
I have a page that is in a sub-directory of my application. When I reference a page that uses “MySkin”, I noticed that ASP.NET renders a link element that walks up to the root of the site and then down into the App_Themes directory. Here is an example link element I found in a rendered ASP.NET page:
<link href="../../App_Themes/MySkin/theme.css" type="text/css" rel="stylesheet" />
Is there a reason that the rendered link element does not use the following instead:
<link href="/App_Themes/MySkin/theme.css" type="text/css" rel="stylesheet" />
Is this a browser compatibility issue or is there another reason?
The reason I am asking is because I am rendering my ASP.NET page using Server.Execute and storing the result in a different directory. Because of this, I would prefer to use the second way to reference my theme’s css.
Thank you!
According to the built-in internal class PageThemeBuildProvider, asp.net create relative path for css files included in the theme directory
To overcome your problem you may try using base tag:
The bad thing about using this approach is your links will break if the application url gets changed.
To minimize such change impact, you may use html include in place of the base tag to include a file containing your base tag as follows:
base.html contains:
this could be created on application begin request:
and added as a literal control to your aspx :
saved.html contains:
UPDATE:
This was tested under asp.net development server, if hosted as application under IIS the AppRoot will not be resolved correctly. To get the correct applications absolute url use: