zoukankan      html  css  js  c++  java
  • 对付CSS兼容问题的十个超级技巧(收藏)

    一、针对firefox ie6 ie7的css样式

      现在大部分都是用!important来 hack,对于ie6和firefox测试可以正常显示,但是ie7对!important可以正确解释, 会导致页面没按要求显示!找到一个针对IE7 不错的hack方式就是使用“*+html”,现在用IE7浏览一下,应该没有问题了现在写一个CSS可以这样:


     Example Source Code
    #abc { color: #333; } /* Moz */
    * html #abc { color: #666; } /* IE6 */
    *+html #abc { color: #999; } /* IE7 */

      那么在firefox下字体颜色显示为#333,IE6下字体颜色显示为#666,IE7下字体颜色显示为#999。

    二、CSS布局中的居中问题

      主要的样式定义如下:


     Example Source Code
    body {TEXT-ALIGN: center;}
    #center { MARGIN-RIGHT: auto; MARGIN-LEFT: auto; }

      说明:首先在父级元素定义TEXT-ALIGN: center;这个的意思就是在父级元素内的内容居中;对于IE这样设定就已经可以了。
      但在mozilla中不能居中。解决办法就是在子元素定义时候设定时再加上“MARGIN-RIGHT: auto;MARGIN-LEFT: auto; ”
      需要说明的是,如果你想用这个方法使整个页面要居中,建议不要套在一个DIV里,你可以依次拆出多个div,只要在每个拆出的div里定义MARGIN-RIGHT: auto;MARGIN-LEFT: auto; 就可以了。

    三、盒模型


     Example Source Code
    #box{
    ;
    //for ie6.0- w\idth:500px;
    //for ff+ie6.0
    }
    #box{
    >//for ff
    ;
    //for ff+ie6.0
    width /**/:500px;
    //for ie6.0-
    }

    四、浮动ie6产生的双倍距离


     Example Source Code
    #box{ float:left; ; margin:0 0 0 100px;
     //这种情况之下IE会产生200px的距离 display:inline; //使浮动忽略}

      这里细说一下block,inline两个元素,Block元素的特点是:总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素);Inline元素的特点是:和其他元素在同一行上,…不可控制(内嵌元素);
      #box{ display:block; //可以为内嵌元素模拟为块元素 display:inline; //实现同一行排列的的效果 diplay:table;

    五、IE与宽度和高度的问题

      IE不认得min-这个定义,但实际上它把正常的width和height当作有min的情况来使。这样问题就大了,如果只用宽度和高度,正常的浏 览器里这两个值就不会变,如果只用min-width和min-height的话,IE下面根本等于没有设置宽度和高度。比如要设置背景图片,这个宽度是  比较重要的。要解决这个问题,可以这样:


     Example Source Code
    #box{ ;80px; height: 35px;}
    html>body #box{ ;auto; height: auto; min- 80px; min-height: 35px;}

    六、页面的最小宽度

      min-width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。但IE不认得这个,而它实际上把  width当做最小宽度来使。为了让这一命令在IE上也能用,可以把一个<div> 放到 <body> 标签下,然后为 div指定一个类:
      然后CSS这样设计:


     Example Source Code
    #container{
    min-;600px;
    ;xpression(document.body.clientWidth < 600? “600px”: “auto” );
    }

      第一个min-width是正常的;但第2行的width使用了Javascript,这只有IE才认得,这也会让你的HTML文档不太正规。它实际上通过Javascript的判断来实现最小宽度。

    七、清除浮动


     Example Source Code
    .hackbox{
    display:table;
    //将对象作为块元素级的表格显示
    }
    或者
    .hackbox{
    clear:both;
    }

      或者加入:after(伪对象),设置在对象后发生的内容,通常和content配合使用,IE不支持此伪对象,非Ie 浏览器支持,所以并不影响到IE/WIN浏览器。这种的最麻烦的


     Example Source Code
    ……#box:after{
    content: “.”;
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
    }

    八、DIV浮动IE文本产生3象素的bug

      左边对象浮动,右边采用外补丁的左边距来定位,右边对象内的文本会离左边有3px的间距.


     Example Source Code
    #box{
    float:left;
    ;}
    #left{
    float:left;
    ;}
    #right{
    ;
    }
    *html #left{
    margin-right:-3px;
    //这句是关键
    }
    HTML代码
    &lt;DIV id=box>
    <DIV id=left></DIV>
    <DIV id=right></DIV>
    </DIV>

    九、属性选择器(这个不能算是兼容,是隐藏css的一个bug)


     Example Source Code
    p[id]{}div[id]{}
    p[id]{}div[id]{}

      这个对于IE6.0和IE6.0以下的版本都隐藏,FF和OPera作用
      属性选择器和子选择器还是有区别的,子选择器的范围从形式来说缩小了,属性选择器的范围比较大,如p[id]中,所有p标签中有id的都是同样式的.

    十、IE捉迷藏的问题

      当div应用复杂的时候每个栏中又有一些链接,DIV等这个时候容易发生捉迷藏的问题。
      有些内容显示不出来,当鼠标选择这个区域是发现内容确实在页面。
      解决办法:对#layout使用line-height属性 或者给#layout使用固定高和宽。页面结构尽量简单。

    版权说明

      如果标题未标有<转载、转>等字则属于作者原创,欢迎转载,其版权归作者和博客园共有。
      作      者:温景良
      文章出处:http://wenjl520.cnblogs.com/  或  http://www.cnblogs.com/

  • 相关阅读:
    I.MX6 Surfaceflinger 机制
    理解 Android Fragment
    RPi 2B DDNS 动态域名
    RPi 2B IPC webcam server
    理解 Android MVP 开发模式
    I.MX6 system.img unpack repack
    can't set android permissions
    VMware Ubuntu 共享文件夹
    解决oracle数据库连接不上的问题
    perfect-scrollbar示例
  • 原文地址:https://www.cnblogs.com/wenjl520/p/1442304.html
Copyright © 2011-2022 走看看