ASP.NET 2.0中CSS失效解决方案

转载 2007年10月14日 12:23:00
经常有人遇到ASP.NET 2.0(ASP.NET 1.x中可能是有效的)中CSS失效的问题,现将主要原因和解决方法罗列如下:

  1、CSS文件路径不正确

  这个问题属于Web开发中的基础问题,一般采用相对路径会出现这样的问题,或者样式文件写在了模板页里面,在内容页与模板页不在同一级目录下时会出现这样的问题。此时你要清楚Web中相对路径的规则,如果你不清楚,可以采用绝对路径的写法试试就知道是不是路径的问题了。

  2、CSS规则写法错误

  这个问题谁也帮不你,只能自己学习CSS的相关知识了。

  3、文件编码问题

  有时候,CSS样式放在aspx文件里有效,而放在独立的文件中无效,这样的问题如果不是路径问题,则就是编码问题造成的,可以将CSS文件用记事本打开,再另存为ANSI格式或者UTF-8格式即可。

  4、权限问题

  这种情况常见的现象是登录之前样式无效,登录之后才有效,这是典型的权限问题造成的。由于web.config配置了所有文件不允许匿名访问,才会出现这样的问题,解决方法就是是标记将样式文件配置为允许匿名访问。例如:

 
<configuration>
 <location path="允许匿名访问的文件夹名称">
 <system.web>
 <authorization>
 <allow users="?"/>
 </authorization>
 </system.web>
 </location>
</configuration>

 

5、单击按钮样式失效

  这种情况最典型的原因是单击按钮事件里有类似Response.Write这样的语句,由于ASP.NET 2.0默认采用http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd文档类型定义,它就要求在<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">的前面不能有任何输出。这种问题的解决方法是采用ClientScriptManager输出,或者采用Literal控件输出内容。

  6、在ASP.NET 1.x里面起作用的样式到ASP.NET 2.0里面失效

  这种问题一般仍然是xhtml1造成的,由于http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd的样式规则与以前的不同,如要加单位,例如width:200;现在要写成width:200px;这种问题的解决方法就是要明确加上单位。

  7、脚本设置的样式无效

  由于xhtml1.DTD要求有单位,因此在设置对象样式的数值时,仍然要加上单位,如obj.style.width = "200px"。下面的代码在Firefox里是无效的(不要抱怨Firefox麻烦)

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script type="text/javascript">
//<![CDATA[
function SetHeight()
{
document.getElementById(
"x").style.height="200"
}
//]]>
</script>
</head>
<body>
<div id="x" style="background:#DDD;height:auto;">测试</div>
<input type="button" value="设置" onclick="SetHeight()" />
</body>
</html>

尽管上面在IE中正常,但在Firefox里面则会出现问题。正确写法为:

以下是引用片段:
document.getElementById("x").style.height="200px"

 

ASP.NET 2.0中CSS失效的问题总结

  • 2009年06月22日 14:38
  • 17KB
  • 下载

asp.net css失效

asp.net在运行脚本alert后有时css会失效,但是用Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "alert", "...
  • huangwei999111
  • huangwei999111
  • 2015-11-13 11:12:38
  • 147

js/css在ajax UpdatePanel 中没有效果的解决方法

js没效果:如果在以UpdatePanel的方式的局部回传中,普通的Javascript代码在这种局部回传中就不会在触发了,就必须使用scriptmanager.RegisterClientScrip...
  • mingWar
  • mingWar
  • 2010-03-01 14:56:00
  • 2211

ASP.NET使用ALERT后,影响CSS的解决方法

不要使用response.write("alert(alert)");这样的方法,而是使用如下:page.RegisterClientScriptBlock("js","alert(alert)") ...
  • trace332
  • trace332
  • 2007-10-20 10:18:00
  • 641

为什么CSS样式表在IIS中会失效?

最近发现我的css样式表在.net2.0中测试时发挥正常,但发布到IIS上后打开就会有问题,第一次打开页面后,样式表没有起作用,如果点页面中的链接返回到本页时就正常了。不知道为什么, google了下...
  • wjdw0624
  • wjdw0624
  • 2008-03-26 11:01:00
  • 592

在asp.net中,把javascript,CSS,image等资源内嵌到DLL使用

ASP.NET(1.0/1.1)给我们提供了一个开发WebControl的编程模型,于是我们摆脱了asp里面的include模式的复用方式。不过1.0/1.1提供的Web控件开发模型对于处理没有ima...
  • bloglife
  • bloglife
  • 2009-03-18 12:35:00
  • 3121

ASP.NET中CSS失效总结及解决方案

ASP.NET中CSS失效总结及解决方案 [复制链接]     发送短消息 UID2精华28 查看公共资料 ...
  • best_caohit
  • best_caohit
  • 2012-08-01 09:51:59
  • 1235

安装ASP.NET AJAX

 安装ASP.NET AJAX简介本主题描述如何安装ASP.NET AJAX Beta测试版本并且可选择安装ASP.NET AJAX社区技术预览(CTP)发布版本,还有ASP.NET AJAX控件工具...
  • Jonly
  • Jonly
  • 2007-08-20 10:41:00
  • 3058

前端开发中的兼容性问题-CSS篇

浏览器兼容性问题一直都让我很头疼,网上大神们给出的解决方法也是五花八门,向后或向前兼容的说法都有,所以自己整理一下,如果有不恰当的欢迎指正!...
  • Mankii
  • Mankii
  • 2017-11-06 16:08:11
  • 174

ASP.NET 中 CSS 不起作用的原因

版权所有(c) 2007  Dorian Deng。署名 共享 非商用。转载请注明出处:http://blog.csdn.net/doriandeng/archive/2007/09/16/17872...
  • doriandeng
  • doriandeng
  • 2007-09-16 16:57:00
  • 1548
收藏助手
不良信息举报
您举报文章:ASP.NET 2.0中CSS失效解决方案
举报原因:
原因补充:

(最多只允许输入30个字)