ASP.NET 2.0中CSS失效解决方案

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

 
<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中使用CSS样式

1  使用link标签去调用样式,即调用css文件中的样式,可以直接将CSS文件拖拽到html页的head下面      此方法先加载css,后加载html 网页标题 2 使...
  • taoerit
  • taoerit
  • 2015年09月19日 15:33
  • 3986

asp.net 2.0中实现防盗链

今天看书时发现一个实现asp.net 2.0中实现防止盗链的方法,其实际的原理就是利用了IIS中HttpHandler模块来处理的。因为比如平时用IIS只是处理如asp,aspx等文件,没处理如iis...
  • jackyrongvip
  • jackyrongvip
  • 2013年07月01日 17:18
  • 490

DIV+CSS网页布局中CSS失效的原因

当我们把做好的页面通过W3C validation验证时,验证程序抛出大量差错和警告,说明你的XHTML尚未完善,可能无法在不同浏览器上保持一致功能。下面十个细微的失效问题难住了大批程序员,本文就告诉...
  • itbyc
  • itbyc
  • 2014年11月11日 13:36
  • 453

ASP.NET 2.0中发送电子邮件

ASP.NET 2.0中发送电子邮件       ASP.NET 2.0 中发送电子邮件变得非常简单。发送电子邮件的类库主要在命名空间System.Net.Mail中,在这个命名空间中有两个...
  • GoodShot
  • GoodShot
  • 2013年05月25日 14:24
  • 932

Hadoop 2.0中单点故障解决方案

Hadoop 1.0内核主要由两个分支组成:MapReduce和HDFS,众所周知,这两个系统的设计缺陷是单点故障,即MR的JobTracker和HDFS的NameNode两个核心服务均存在单点问题,...
  • guzicheng
  • guzicheng
  • 2014年12月17日 13:40
  • 519

《精通CSS:高级Web标准解决方案》学习过程--V

第九章:bug 在这个行当,bug,这个人见人爱的东西,人人都见过,那么你有没有系统的学过,不是记下所有的bug以及相应的处理方法(我是记不住),那么追究产生bug的原因就显得很重要了。其实css不...
  • onealcsh126
  • onealcsh126
  • 2016年04月26日 15:02
  • 344

如何在asp.net页面使用css和js

记录在c#开发中的小问题。
  • u014113117
  • u014113117
  • 2016年05月02日 17:54
  • 319

用VS2010建立解决方案

三层结构,会有多个项目。为了让各项目之间的关系反映在目录结构上所以要建立一个解决方案。 1.建立解决方案: 文件->新建项目->其它项目类型->Visual Studio解决方案->空白解决方案...
  • u012690204
  • u012690204
  • 2014年10月27日 14:10
  • 1218

asp.net 2.0中删除数据的操作

一个很典型的场景,一个GRIDVIEW中的每个数据行,有两个图片按钮 “操作(修改)”,“删除”, 先来看前端的代码                                       ...
  • jackyrongvip
  • jackyrongvip
  • 2013年07月01日 16:14
  • 489

Asp.Net---css样式的使用方式

Css样式的使用大致分为三种 咱们先来看看一张总括图     1 使用连接的形式调用 有两种发方式调用...
  • han_yankun2009
  • han_yankun2009
  • 2013年06月17日 14:26
  • 7580
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET 2.0中CSS失效解决方案
举报原因:
原因补充:

(最多只允许输入30个字)