BeC*_*ool 12 css asp.net-mvc css3pie asp.net-mvc-2
我一直试图在我的MVC项目中使用Css3pie来渲染圆角面板但到目前为止没有运气.
我使用正常的html页面跟踪示例,它完美地工作,但不是在我的MVC项目中.我认为这与在'MVC中混淆的'pie.htc'文件的路径有关
我将'pie.htc'文件放在项目文件夹(root)和我的css文件中,我使用:behavior:url(/PIE.htc);
我认为需要修改MVC路由器以接受htc文件扩展名?对不起,我对MVC很新.有没有人尝试过pie.htc并让它在MVC项目中工作,请帮忙吗?
谢谢!
小智 16
作为旁注(也许它会解决您的问题)如果您不希望在您的根目录下使用.htc文件,您可以执行以下操作来解决行为固有的相对路径问题.这不是最漂亮的解决方案,但效果很好 -
在您的css中,将行为定义为:behavior: url(CSS3PIE);
然后在你的Global.asax.cs中有以下代码:
protected void Application_BeginRequest(Object sender, EventArgs e)
{
CheckForCSSPIE();
}
private void CheckForCSSPIE()
{
if (!Regex.IsMatch(Request.Url.ToString(), "CSS3PIE"))
{
return;
}
const string appRelativePath = "~/Content/css/PIE.htc";
var path = VirtualPathUtility.ToAbsolute(appRelativePath);
Response.Clear();
Response.StatusCode = (int)HttpStatusCode.MovedPermanently;
Response.RedirectLocation = path;
Response.End();
}
Run Code Online (Sandbox Code Playgroud)
它只会查找匹配"CSS3PIE"的任何请求,并从正确的位置返回.htc文件.