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


Posted on October 12, 2008


经常有人遇到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文档类型定义,它就要 求在的前面不能有任何输出。这种问题的解决方法是采用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"


标签:.NETasp.net

其它推荐日志:

个人网站设计经验谈

AccessDataSource中参数传递的问题

网站信息的可用性设计

javascript 判断是否为数字

搜集几个免费ASP空间,不能保证其时效性,仅供参考实践用!

IE6--让我说你什么好!编码!还是编码!

仿XP关机效果的弹出窗口功能

C#编码标准--编码习惯(转)

什么叫有源音箱?

关于linkbutton点击后弹出新窗口的代码

介绍一个web2.0站点模板

QQ邮箱VIP帐号在FOXMAIL配置

c#中String跟string的“区别”

VS2005出现visual sourcesafe login窗口

System.Data.OleDb.OleDbException: 未指定错误

DW做ASP程序时关于数据库的几个常见问题

学习ajax-xmlhttp:open方法

关于如何生成随机记录-如何解决每次RND的结果都一样的问题?

逗号表达式

asp错误0x80004005的解决方法!

Understanding Page Inheritance in ASP.NET 2.0

细说HTML元素的ID和Name属性的区别

什么是WINPE系统?

IE和Firefox的js兼容性整理

搞定CSS SPAN和DIV的区别

IE7启动时总打开runonce2.aspx的解决办法

嵌入式系统VxWorks介绍及编程

用c#读文件

瑞星熊猫烧香专杀工具(尼姆雅蠕虫)

如何动态生成服务器控件!

将VIEWSTATE保存在服务器端,减少网络传输负载

一行代码杜绝iframe挂马

重温字符编码ASCII,Unicode和UTF-8

The keywords of JAVA

vs2008【断点无效】解决方法

Manhattan Distance Calculation(曼哈顿距离算法)

二进制算术操作笔记-php

关于“System.NullReferenceException: 未将对象引用设置到对象的实例”问题原因

C#二进制数据写入文件

C#中关于get和set的详细例子介绍


Search
最新评论
推荐日志
微信扫一扫