ASP.NET2.0中CSS失效解决方案

开发 前端
经常有人遇到ASP.NET2.0(ASP.NET1.x中可能是有效的)中CSS失效的问题,这里将主要原因和解决方法罗列下来供大家参考,主要包括七个方面,相信你一定会感兴趣。

本文向大家描述一下ASP.NET2.0中CSS失效解决方案,比如说CSS文件路径不正确为题,这个问题属于Web开发中的基础问题,此时你要清楚Web中相对路径的规则,如果你不清楚,可以采用绝对路径的写法试试就知道是不是路径的问题了。

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配置了所有文件不允许匿名访问,才会出现这样的问题,解决方法就是是标记将样式文件配置为允许匿名访问。例如:

以下是引用片段: 

  1. <configuration> 
  2. <locationpathlocationpath="允许匿名访问的文件夹名称"> 
  3. <system.web> 
  4. <authorization> 
  5. <allowusersallowusers="?"/> 
  6. </authorization> 
  7. </system.web> 
  8. </location> 
  9. </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麻烦)

以下是引用片段:

  1. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
  2.  
  3. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
  4. <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> 
  5. <head> 
  6. <scripttypescripttype="text/javascript"> 
  7. //<![CDATA[  
  8. functionSetHeight()  
  9. {  
  10. document.getElementById("x").style.height="200"  
  11. }  
  12. //]]> 
  13. </script> 
  14. </head> 
  15. <body> 
  16. <dividdivid="x"style="background:#DDD;height:auto;">测试</div> 
  17. <inputtypeinputtype="button"value="设置"onclick="SetHeight()"/> 
  18. </body> 
  19. </html> 
  20.  

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

以下是引用片段:

  1. document.getElementById("x").style.height="200px" 
  2.  

【编辑推荐】

  1. CSS相对定位和绝对定位区别揭秘
  2. CSS浮动属性float用法指导
  3. CSS样式表特点及嵌入网页的四种途径
  4. 深入学习六大CSS选择符的使用
  5. 解读DIV CSS网页布局中CSS无效十个原因

 

责任编辑:佚名 来源: yesky.com
相关推荐

2010-09-02 15:18:42

CSSASP.NET

2009-08-04 14:44:40

callback实现机ASP.NET2.0

2009-07-29 14:59:26

asp.net1.1ASP.NET2.0

2009-07-29 15:17:42

验证控件ASP.NET1.1ASP.NET2.0

2009-07-30 13:18:31

2009-07-31 15:42:38

自定义providerASP.NET2.0

2009-07-22 17:28:07

CSS文件ASP.NET 2.0

2009-07-29 15:58:54

静态文件处理ASP.NET

2010-06-02 16:49:24

MySQL存储过程

2009-08-07 16:18:08

ASP.NET2.0数

2009-07-21 15:23:55

预编译Web应用程序ASP.NET

2009-07-21 15:27:12

ASP.NET 2.0

2009-07-24 11:24:33

ASP.NET中文乱码

2009-12-14 10:03:16

ASP.NET 2.0

2009-08-04 11:19:30

Web ResourcASP.NET 2.0

2009-07-29 11:29:16

ASP.NET1.1ASP.NET2.0

2009-12-14 17:50:45

ASP.NET 2.0

2009-08-05 17:43:48

ASP.NET 2.0

2009-07-21 15:34:32

ASP.NET 2.0

2009-07-29 15:06:16

asp.net1.1asp.net2.0
点赞
收藏

51CTO技术栈公众号