经常有人遇到ASPNET (ASPNET x中可能是有效的)中CSS失效的问题本文将主要原因和解决方法A&Q列出做出如CSS文件路径不正确等问题的解答
经常有人遇到ASPNET (ASPNET x中可能是有效的)中CSS失效的问题现将主要原因和解决方法罗列如下
QCSS文件路径不正确
A这个问题属于Web开发中的基础问题一般采用相对路径会出现这样的问题或者样式文件写在了模板页里面在内容页与模板页不在同一级目录下时会出现这样的问题此时你要清楚Web中相对路径的规则如果你不清楚可以采用绝对路径的写法试试就知道是不是路径的问题了
QCSS规则写法错误
A这个问题谁也帮不你只能自己学习CSS的相关知识了
Q文件编码问题
A有时候CSS样式放在aspx文件里有效而放在独立的文件中无效这样的问题如果不是路径问题则就是编码问题造成的可以将CSS文件用记事本打开再另存为ANSI格式或者UTF格式即可
Q权限问题
A这种情况常见的现象是登录之前样式无效登录之后才有效这是典型的权限问题造成的由于webconfig配置了所有文件不允许匿名访问才会出现这样的问题解决方法就是是标记将样式文件配置为允许匿名访问例如
<configuration>
<location path=允许匿名访问的文件夹名称>
<systemweb>
<authorization>
<allow users=?/>
</authorization>
</systemweb>
</location>
</configuration>
Q单击按钮样式失效
A这种情况最典型的原因是单击按钮事件里有类似ResponseWrite这样的语句由于ASPNET 默认采用http://wwwworg/TR/xhtml/DTD/xhtmltransitionaldtd文档类型定义它就要求在的前面不能有任何输出这种问题的解决方法是采用ClientScriptManager输出或者采用Literal控件输出内容
Q在ASPNET x里面起作用的样式到ASPNET 里面失效
A这种问题一般仍然是xhtml造成的由于http://wwwworg/TR/xhtml/DTD/xhtmltransitionaldtd的样式规则与以前的不同如要加单位例如width:; 现在要写成width:px; 这种问题的解决方法就是要明确加上单位
Q脚本设置的样式无效
A由于xhtmlDTD要求有单位因此在设置对象样式的数值时仍然要加上单位如objstylewidth = px下面的代码在Firefox里是无效的(不要抱怨Firefox麻烦)
<!DOCTYPE html PUBLIC
//W
C//DTD XHTML
Transitional//EN
http://www
w
org/TR/xhtml
/DTD/xhtml
transitional
dtd
>
<html xmlns=http://wwwworg//xhtml>
<head>
<script type=text/javascript>
//<![CDATA[
function SetHeight()
{
documentgetElementById(x)styleheight=
}
//]]>
</script>
</head>
<body>
<div id=x style=background:#DDD; height:auto; >测试</div>
<input type=button value=设置 onclick=SetHeight() />
</body>
</html>
尽管上面在IE中正常但在Firefox里面则会出现问题正确写法为
documentgetElementById(x)styleheight=px