asp.net2.0中css失效的解决方法

 更新时间:2014年01月15日 11:00:42   作者:  
经常有人遇到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配置了所有文件不允许匿名访问,才会出现这样的问题,解决方法就是将<location>标记将样式文件配置为允许匿名访问。例如:

复制代码 代码如下:

<configuration>
   <location path="允许匿名访问的文件夹名称或者文件路径">
      <system.web>
         <authorization>
            <allow users="?"/>
         </authorization>
      </system.web>
   </location>
</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麻烦)

复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <script type="text/javascript">
  //<![CDATA[
  function SetHeight()
  {
    document.getElementById("x").style.height="200"
  }
  //]]>
  </script>
</head>
<body>
<div id="x" style="background:#DDD;height:auto;">测试</div>
<input type="button" value="设置" onclick="SetHeight()" />
</body>
</html>

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

复制代码 代码如下:

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

相关文章

  • ASP.NET Core中使用令牌桶限流的实现

    ASP.NET Core中使用令牌桶限流的实现

    这篇文章主要介绍了ASP.NET Core中使用令牌桶限流的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • GridView自定义分页实例详解(附demo源码下载)

    GridView自定义分页实例详解(附demo源码下载)

    这篇文章主要介绍了GridView自定义分页的方法,结合实例形式较为详细的分析了GridView自定义分页所涉及的样式布局及功能实现相关技巧,并附带demo源码供读者下载参考,需要的朋友可以参考下
    2016-03-03
  • asp.net UrlReWriter使用经验小结

    asp.net UrlReWriter使用经验小结

    UrlRewriter 是微软封装好了的一个URL重写组件。使用它可以让我节约很多自已开发的时间。 好了,开始讲述我的应用经验,这只是很菜鸟的经验,高手就不用看了。
    2008-11-11
  • C# Quoted-Printable编码、解码

    C# Quoted-Printable编码、解码

    Class for encoding and decoding a string to QuotedPrintable
    2008-12-12
  • ADO.NET之连接池技术的使用详解

    ADO.NET之连接池技术的使用详解

    本篇文章是对连接池技术的使用进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 自写一个模仿Dictionary与Foreach的实现及心得总结

    自写一个模仿Dictionary与Foreach的实现及心得总结

    利用闲暇时间自己写一个类模仿Dictionary实现,如果一个类进行foreach的话,该类必须实现IEnumerable,集合要支持foreach方式的遍历,必须实现IEnumerable接口,感兴趣的你可不要错过了哈
    2013-02-02
  • Asp.net获取当前目录的方法小结

    Asp.net获取当前目录的方法小结

    有时候可能出现找不到类的情况,请引用System.Web.dll
    2013-07-07
  • asp.net实现的群发邮件功能详解

    asp.net实现的群发邮件功能详解

    这篇文章主要介绍了asp.net实现的群发邮件功能,结合具体实例形式分析了asp.net基于SMTP服务群发QQ邮件的相关操作技巧与注意事项,需要的朋友可以参考下
    2017-05-05
  • DAM 简单跨数据库ADO.NET组件

    DAM 简单跨数据库ADO.NET组件

    这是一个可以实现简单跨数据库基于ADO.NET的组件。您可以在DAL层透过它来访问数据库。这是一个以前写过一个小组件的修改版.
    2011-01-01
  • ASP.NET中XML转JSON的方法实例

    ASP.NET中XML转JSON的方法实例

    这篇文章主要介绍了ASP.NET中XML转JSON的方法,实例讲述了XML转json的原理与实现过程,具有一定的实用价值,需要的朋友可以参考下
    2014-10-10

最新评论