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