ASP.NET2.0中CSS失效如何解决
这篇文章给大家介绍ASP.NET2.0中CSS失效如何解决,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
ASP.NET2.0中CSS失效解决方案
经常有人遇到ASP.NET2.0(ASP.NET1.x中可能是有效的)中CSS失效的问题,现将主要原因和解决方法罗列如下:
1、CSS文件路径不正确
这个问题属于Web开发中的基础问题,一般采用相对路径会出现这样的问题,或者样式文件写在了模板页里面,在内容页与模板页不在同一级目录下时会出现这样的问题。此时你要清楚Web中相对路径的规则,如果你不清楚,可以采用绝对路径的写法试试就知道是不是路径的问题了。
2、CSS规则写法错误
这个问题谁也帮不你,只能自己学习CSS的相关知识了。
3、文件编码问题
有时候,CSS样式放在aspx文件里有效,而放在独立的文件中无效,这样的问题如果不是路径问题,则就是编码问题造成的,可以将CSS文件用记事本打开,再另存为ANSI格式或者UTF-8格式即可。
4、权限问题
这种情况常见的现象是登录之前样式CSS无效,登录之后才有效,这是典型的权限问题造成的。由于web.config配置了所有文件不允许匿名访问,才会出现这样的问题,解决方法就是是标记将样式文件配置为允许匿名访问。例如:
以下是引用片段:
<configuration> <locationpathlocationpath="允许匿名访问的文件夹名称"> <system.web> <authorization> <allowusersallowusers="?"/> </authorization> </system.web> </location> </configuration>
5、单击按钮样式CSS失效
这种情况最典型的原因是单击按钮事件里有类似Response.Write这样的语句,由于ASP.NET2.0默认采用http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd文档类型定义,它就要求在<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">的前面不能有任何输出。这种问题的解决方法是采用ClientScriptManager输出,或者采用Literal控件输出内容。
6、在ASP.NET1.x里面起作用的样式到ASP.NET2.0里面CSS失效
这种问题一般仍然是xhtml1造成的,由于http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd的样式规则与以前的不同,如要加单位,例如width:200;现在要写成width:200px;这种问题的解决方法就是要明确加上单位。
7、脚本设置的样式CSS无效
由于xhtml1.DTD要求有单位,因此在设置对象样式的数值时,仍然要加上单位,如obj.style.width="200px"。下面的代码在Firefox里是无效的(不要抱怨Firefox麻烦)
以下是引用片段:
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> <head> <scripttypescripttype="text/javascript"> //<![CDATA[ functionSetHeight() { document.getElementById("x").style.height="200" } //]]> </script> </head> <body> <dividdivid="x"style="background:#DDD;height:auto;">测试</div> <inputtypeinputtype="button"value="设置"onclick="SetHeight()"/> </body> </html>
尽管上面在IE中正常,但在Firefox里面则会出现问题。正确写法为:
以下是引用片段:
document.getElementById("x").style.height="200px"
关于ASP.NET2.0中CSS失效如何解决就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341