zoukankan      html  css  js  c++  java
  • CSS的兼容性与BUG处理

    骨灰级清除浮动


    .clearfix:after {
        content: ".";
        display: block;
        height: 0;
        clear: both;
        visibility: hidden;
        overflow: hidden;
        *zoom:1; //兼容ie
    }
    

    内联元素相连之间存在间隙问题


    原因:内联元素是当做字体来处理的,字体之间是有间隔的

    解决方法:

    1.多个标签写在一行

    2.将要闭合标签的地方与开始标签的地方重合

    3.使用注释头尾相连

    4.在父级上写:font-size:0;

    5.使用display:block(img是内联元素)

    6.使用letter-spacing属性

    块级元素包裹内联元素的时候,总会出现几像素的差问题


    <!--例子1-->
    <div>
    <img src="http://images.cnblogs.com/cnblogs_com/zqzjs/757818/o_u=3986871593,628400456_fm=21_gp=0.jpg">
    </div>
    
    <!--例子2-->
    <ul>
    <li>
    <img src="http://images.cnblogs.com/cnblogs_com/zqzjs/757818/o_u=3986871593,628400456_fm=21_gp=0.jpg">
    </li>
    </ul>
    
    <!--例子3-->
    <div>
    <span>asdasdasd</span>
    </div>
    

    解决方法:设置内联元素属性:display:block;

    CSS垂直居中方法


    使用时一定要给出元素宽高

      200px;
            height: 200px;
            margin: auto;
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
    

    CSS Hack


    指的是针对不同的浏览器写对应的CSS

    有三种hack方式

    1.html hack(添加不同的类来区别)

    <!--[if lt IE 7 ]><html class="ie6" lang="zh-cn"><![endif]-->
    <!--[if IE 7 ]><html class="ie7" lang="zh-cn"><![endif]-->
    <!--[if IE 8 ]><html class="ie8" lang="zh-cn"><![endif]-->
    <!--[if IE 9 ]><html class="ie9" lang="zh-cn"><![endif]-->
    

    2.选择器 hack

    * html .test{color:#090;} /* For IE6 */
    * + html .test{color:#ff0;} /* For IE7 */
    

    3.属性hack

    color:#fff; /*:选择IE8+和Opera*/
    color:#0909; /* For IE浏览器 */
    *color:#f00; /* For IE7 */
    _color:#ff0; /* For IE6 */
    

    ie6.7不支持box-sizing: border-box问题


    解决:使用https://github.com/Schepp/box-sizing-polyfill这个垫片,稳定性差

    注意:*behavior: url(../resource/js/lab/boxsizing.htc);这个URL是相对于HTML页面的!!

    ul中li下面的间隔线用li布局边框问题


    在IE低版本下有bug,会多出li的宽高

    解决:间隔线使用li的border去做

    ie8及以下的浏览器不支持:befor.:after问题


    使用left:expression(eval(document.documentElement.scrollLeft))top:expression(eval(document.documentElement.scrollTop))

    .leftTop{
        position:absolute;
        left:expression(eval(document.documentElement.scrollLeft));
        top:expression(eval(document.documentElement.scrollTop));
    }
    

    低版本浏览器下position:fixed闪动问题


    解决:

    *html{ 
      background-image:url(about:blank); 
      background-attachment:fixed;
    }
    

    IE6双倍margin,padding边距的问题


    内部元素一旦浮动,就会出现双倍的BUG

    解决:给内部元素添加display:inline属性

    IE6中设置宽高位10px的时候出现的是长方形问题


    这个现象的另一种情况是:在IE6中定义比较小的高度问题。

    原因:IE6有默认行高

    解决:使用font-size:0;line-height:0;

    IE6无法识别伪对象:first-letter/:first-line问题


    类似这样解决:
    p:first-letter {}

    在first-letter与"{"间增加空格

    IE6下忽略!important问题


    如下写法在IE6下不起作用

    div{
      color:#f00!important;
      color:#000;}
    

    解决:更改写法

    div{color:#f00!important;}
    div{color:#000;}
    

    父元素与子元素之间的margin-top问题(BFC问题)


    现象:给第一个子元素设置margin-top属性后,父元素也会下移

    代码示例:

     <style type="text/css">
            .wrapper {
          position: relative;
           500px;
          height: 500px;
          background-color: #ddd;
         }
        .content{
            background-color:#6699FF;
            200px;
            height:200px;
        } 
        </style>
    
    <div class="wrapper">
            <div class="content"></div>
        </div>  
    
    

    解决:

    1、修改父元素的高度,增加padding-top样式模拟(padding-top:1px;常用)

    2、为父元素添加overflow:hidden;样式即可(完美)

    3、为父元素或者子元素声明浮动(float:left;可用)

    4、为父元素添加border(border:1px solid transparent可用)

    5、为父元素或者子元素声明绝对定位

    元素浮动导致父元素塌陷问题


    见例子:

    <div class='outer' style=" 300px;background-color: gray">
            
            <div class='innner' style=" 100px;height: 100px;background-color: blue;float: left;"></div>
    
        </div>
    

    解决方法:

    1.给父元素添加overflow:hidden属性

    2.给父元素添加清除浮动伪类

    .outer:after {
            content: ".";
            display: block;
            height: 0;
            clear: both;
            visibility: hidden;
            overflow: hidden;
        }
    

    IE6中li之间会有间距

    解决方法:float: left;

    IE6挨着的div元素产生3像素差值问题


    解决:使用绝对定位然后内补边

    相邻的块状元素margin叠加问题(BFC问题)


    见例子:

    p{
            margin-bottom: 100px;
            margin-top: 100px;
        }
    
    ...
    
     <div>
            <p>asdasdasdas中国</p>
            <p>asdasdasdas中国</p>
            <p>asdasdasdas中国</p> 
        </div>
    

    结果p直接的margin发生了合并变成了50px。

    解决:给最后一个p元素添加left/right浮动,触发BFC。
    参考链接:解决margin合并(折叠)的方法

  • 相关阅读:
    牛客多校第一场 A Equivalent Prefixes 单调栈(笛卡尔树)
    HDU多校第三场 Hdu6606 Distribution of books 线段树优化DP
    (待写)
    Hdu6586 String 字符串字典序贪心
    2019HDU多校第一场1001 BLANK (DP)(HDU6578)
    iOS触摸事件
    iOS获取相册/相机图片-------自定义获取图片小控件
    自定义表情输入框
    iOS版本、iPhone版本、Xcode版本比对
    Swift备忘录
  • 原文地址:https://www.cnblogs.com/zqzjs/p/6379489.html
Copyright © 2011-2022 走看看