首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 技术专题 | 电子书下载 | 教学视频 | 网页设计 | 平面设计 | 搜索 | 博客 | 论坛
中国IT实验室Dotnet频道
中国IT教育
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> ASP.NET >> 文章正文

ASP.NET2.0中CSS失效解决问答

文章来源ChinaItLab 作者佚名 更新时间2007-11-2 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

  经常有人遇到ASP.NET 2.0(ASP.NET 1.x中可能是有效的)中CSS失效的问题,本文将主要原因和解决方法A&Q列出,做出如CSS文件路径不正确等问题的解答。现将主要原因和解决方法罗列如下:

  1、Q:CSS文件路径不正确

  A:这个问题属于Web开发中的基础问题,一般采用相对路径会出现这样的问题,或者样式文件写在了模板页里面,在内容页与模板页不在同一级目录下时会出现这样的问题。此时你要清楚Web中相对路径的规则,如果你不清楚,可以采用绝对路径的写法试试就知道是不是路径的问题了。

  2、Q:CSS规则写法错误

  A:这个问题谁也帮不你,只能自己学习CSS的相关知识了。

  3、Q:文件编码问题

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

  4、Q:权限问题

  A:这种情况常见的现象是登录之前样式无效,登录之后才有效,这是典型的权限问题造成的。由于web.config配置了所有文件不允许匿名访问,才会出现这样的问题,解决方法就是是标记将样式文件配置为允许匿名访问。例如:

configuration
<location path="允许匿名访问的文件夹名称">
system.web>
authorization
<allow users="?"/>
</authorization>
</system.web>
</location>
</configuration>

  5、Q:单击按钮样式失效

  A:这种情况最典型的原因是单击按钮事件里有类似Response.Write这样的语句,由于ASP.NET 2.0默认采用http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd文档类型定义,它就要求在的前面不能有任何输出。这种问题的解决方法是采用ClientScriptManager输出,或者采用Literal控件输出内容。

  6、Q:在ASP.NET 1.x里面起作用的样式到ASP.NET 2.0里面失效

  A:这种问题一般仍然是xhtml1造成的,由于http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd的样式规则与以前的不同,如要加单位,例如width:200; 现在要写成width:200px; 这种问题的解决方法就是要明确加上单位。

  7、Q:脚本设置的样式无效

  A:由于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"

【责编:John】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题
 ·展现C#世界 C#程序设计专题
 ·Java入门 Tomcat的配置技巧精华专题
 ·Oracle RMAN物理备份技术详解
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航