zoukankan      html  css  js  c++  java
  • CSS样式丢失总结(转载)

    转载自【孟子E章】:http://blog.csdn.net/net_lover/archive/2007/08/27/1760521.aspx

    经常有人遇到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控件输出内容。

        [转载补充]

        后台使用Response.Write("<script>alert('****');</script>")方法后,可能导致样式丢失。

        原因是:
        因为Resonse将弹出提示框的脚本输出在<html></html>标签之外,即:
        <script>alert('****'); </script>
        <html> </html>

        解决办法有两个:

        1. 使用ClientScriptManager方式输出

        2. 页面使用<asp:Literal>控件,用LiteralID.Text = "<script>alert('请输入赠品数量');</script>";代替Reponse.Write()方法。

        3. <asp:Literal>控件能执行<script></script>脚本段,则意味着,你还可以这样使用:LiteralID.Text = "<script>window.open('a.html');window.location.href=window.location.href;</script>";

    6.在ASP.NET 1.x里面起作用的样式到ASP.NET 2.0里面失效
        这种问题一般仍然是xhtml1造成的,由于http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd的样式规则与以前的不同,如要加单位,例如200;现在要写成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"

    http://blog.csdn.net/Lisliefor/archive/2009/09/24/4588650.aspx

  • 相关阅读:
    在SSH框架下按条件分页查询
    关于从数据库中取出来的数据在jsp页面上级联显示出来的问题,和ajax处理乱码
    在js中下拉列表值的选定
    java中的日期转换方法
    用js判断输入文本框的内容类型
    将selenium录制的脚本转换为java脚本到Eclipse中运行(一)
    selenium录制并回放请求-心得(一)
    selenium java版本的安装方法与注意事项
    python编写的面向对象的XXE自动化检测工具(对单个功能进行检测)
    微服务&spring cloud架构系列
  • 原文地址:https://www.cnblogs.com/johnwonder/p/1767357.html
Copyright © 2011-2022 走看看