ASP.NET 2.0中的CSS文件

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

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

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

 

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional
    //EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
    > 
  2. <html xmlns="http://www.w3.org/1999/xhtml"> 
  3. <head> 
  4.   <script type="text/javascript"> 
  5.   //<![CDATA[  
  6.   function SetHeight()  
  7.   {  
  8.     document.getElementById("x").style.height="200"  
  9.   }  
  10.   //]]> 
  11.   </script> 
  12. </head> 
  13. <body> 
  14. <div id="x" style="background:#DDD;height:auto;">测试</div> 
  15. <input type="button" value="设置" onclick="SetHeight()" /> 
  16. </body> 
  17. </html> 


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

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

以上介绍ASP.NET 2.0中的CSS文件。

【编辑推荐】

  1. 浅谈ASP.NET MVC框架
  2. 介绍ASP.NET MVC中的MvcAjaxPanel
  3. ASP.NET MVC框架拯救UpdatePanel
  4. 用ASP.NET MVC源代码寻找解决方案
  5. ASP.NET MVC框架的ActionInvoker
责任编辑:佚名 来源: IT168
相关推荐

2009-07-23 16:28:20

URL映射ASP.NET 2.0

2009-07-22 17:23:03

XmlDataSourASP.NET 2.0

2009-07-20 15:48:10

OWC组件ASP.NET 2.0

2009-07-30 15:17:16

ASP.NET 2.0

2009-07-20 18:02:48

GridView控件ASP.NET 2.0

2009-07-21 11:14:19

max-age设置ASP.NET 2.0

2009-07-27 15:58:25

添加GridView

2009-07-21 15:55:59

使用Web PartsASP.NET 2.0

2009-07-21 15:27:12

ASP.NET 2.0

2009-07-28 14:06:28

ASP.NET 2.0

2009-12-14 17:50:45

ASP.NET 2.0

2009-01-07 11:38:22

ASP.NET.NET错误记录

2009-07-30 14:00:21

ASP.NET 2.0

2009-07-22 17:21:27

ASP.NET 2.0

2009-07-21 14:37:13

Profile Pro优化ASP.NET 2

2009-07-30 14:55:43

ASP.NET 2.0

2009-05-11 13:48:00

ASP.NET 2.0缓存效率

2009-08-05 17:26:25

ASP.NET 2.0

2010-09-06 13:51:38

CSS失效CSS

2009-07-24 10:10:22

ASP.NET
点赞
收藏

51CTO技术栈公众号