css3复习

清除浮动:
  1. 方法:clear清除浮动(添加空div法)
    在浮动元素下方添加空div,并给该元素写css样式: {clear:both;height:0;overflow:hidden;}
  2. 方法:给浮动元素父级设置高度
    缺点:在浮动元素高度不确定的时候不适用
  3. 方法:以浮制浮(父级同时浮动)
    缺点:需要给每个浮动元素父级添加浮动,浮动多了容易出现问题。
  4. 父级设置成inline-block
    缺点:父级的margin左右auto失效,无法使用margin: 0 auto;居中了
  5. br 清浮动:





    br 标签自带clear属性,将它设置成both其实和添加空div原理是一样的;
    不符合工作中:结构、样式、行为,三者分离的要求.
  6. 给父级添加overflow:hidden 清浮动方法;
    需要配合 宽度 或者 zoom 兼容IE6 IE7;
    overflow: hidden;
    *zoom: 1;
  7. 万能清除法 after伪类 清浮动(现在主流方法,推荐使用)
    选择符:after{
    content:".";
    clear:both;
    display:block;
    height:0;
    overflow:hidden;
    visibility:hidden;
    }
    同时为了兼容 IE6,7 同样需要配合zoom使用例如:
    ①.clear:after{content:'';display:block;clear:both;height:0;overflow:hidden;visibility:hidden;}
    ②.clear{zoom:1;}
    需要注意的东西:
    after伪类: 元素内部末尾添加内容;
    :after{content"添加的内容";} IE6,7下不兼容
    zoom 缩放 :
    a、触发 IE下 haslayout,使元素根据自身内容计算宽高。
    b、FF 不支持;
块级元素和行内元素
在标准文档流里面 块级元素具有以下特点:

①总是在新行上开始,占据一整行;
②高度,行高以及外边距和内边距都可控制;
③宽带始终是与浏览器宽度一样,与内容无关;
④它可以容纳[内联元素])和其他块元素。

行内元素的特点:

①和其他元素都在一行上;
②高,行高及外边距和内边距部分可改变;
③宽度只与内容有关;
④行内元素只能容纳文本或者其他行内元素。

不可以设置宽高,其宽度随着内容增加,高度随字体大小而改变,内联元素可以设置外边界,但是外边界不对上下起作用,只能对左右起作用,也可以设置内边界,但是内边界在ie6中不对上下起作用,只能对左右起作用。

块级元素:div , p , form, ul, li , ol, dl, form, address, fieldset, hr, menu, table
行内元素:span, strong, em, br, img , input, label, select, textarea, cite,

转换的方式是用css的display属性:
display:block; // 转换为块级
display:inline; // 转换为行内

隐藏元素
  1. 方法:display:none;
    "display:none;"后浏览器不会解析该元素,“none”就是没有,消失了,所以他不会再文档流中占位。
  2. 方法:visibility:hidden
    hidden”也就是隐藏了,但是它所在的位置仍然还在,就像你把你个文件给隐藏了,但是这个文件在你的硬盘中仍然是占据一定空间的,只是你看不见而已, 它不会导致浏览器重排和重绘 。

你可能感兴趣的:(css3复习)