当前位置: 移动技术网 > IT编程>开发语言>.net > asp.net2.0中css失效的解决方法

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

操控飞船起飞,东方大学城论坛,威克集团

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"

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网