浮动与定位

浮动

  • 浮动元素的特性
  1. 浮动元素脱离文档流,遇到父级包含框或者相邻的浮动元素后停下来。
  2. 浮动元素在一排显示,没有空隙。
  3. 浮动元素运用到内联元素上时可以让其支持宽高,像inline-block一样。
  4. 由于脱离文档流,浮动元素无法撑开父级元素的高度。
  5. 对其他浮动元素:浮动元素会按照顺序排列下去,若父容器剩余的宽度不够放下下一个浮动元素,那么它将向下移动,若是高度不同,在下移的过程中,浮动元素还有可能会被卡住。
  6. 浮动元素会提升层级,文档流中的文字图片内容与浮动元素所占空间重合,文字会围绕浮动元素。
  • 清浮动
  1. 给浮动元素的父级加高度
  2. 给浮动元素的父级也加浮动
  3. 给浮动元素的父级加
       display: block
    
  4. 在浮动元素的最后设置空标签,如
       <div style="clear:both;"></div>
    
  5. 给浮动元素下面加
        <br clear="all"/> 
    
  6. 给浮动元素父级加
    .clear{zoom:1}  /*IE6/7下不支持after伪类  需要触发haslayout zoom*/
    .clear:after{content:"";display:block;clear:both;}
    
  1. 利用BFC特性,使父容器形成一个新的BFC,便具有BFC包含浮动的特质,高度就可以撑起来。

定位

inherit 规定应该从父元素继承 position 属性的值
static 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。

relative 生成相对定位的元素,相对于其正常位置进行定位。还在文档流中,原来所占用的位不会被其它元素所占有。如,"left:20" 会向元素的 LEFT 位置添加 20 像素。

absolute 生成绝对定位的元素,相对于 static 定位以外的第一个祖先元素进行定位。如果没有这样的祖先元素,则参照初始块即浏览器视口。
元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

fixed 生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定

sticky CSS3新属性,表现类似position:relative和position:fixed的合体,在目标区域在屏幕中可见时,它的行为就像position:relative; 而当页面滚动超出目标区域时,它的表现就像position:fixed,它会固定在目标位置

*注意:
如果同时定义了left和right值,且width和height有值,那么left生效,right无效,同样,同时定义了top和bottom,top生效

z-index

  • z-index 属性指定一个元素的堆叠顺序。因为绝对定位的元素脱离了普通流,所以绝对定位的元素可以覆盖页面上的其它元素。这时可以通过给元素设置z-index属性来控制叠放顺序,拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。

  • z-index有三个属性

  1. auto 默认。堆叠顺序与父元素相等。
  2. number设置元素的堆叠顺序。
  3. inherit规定应该从父元素继承 z-index 属性的值。

深入理解CSS中的层叠上下文和层叠顺序

position:relative和负margin都可以使元素位置发生偏移?二者有什么区别

  • position: ralative是相对于自身进行定位,不会脱离文档流,所以不影响其他元素的位置。
  • margin: 可以使元素偏移同时还会影响文档流中的其他元素的位置。

BFC

BFC就是页面上一个隔离出来的独立容器,容器里面的子元素不会影响到外面的元素。

  • 如何形成BFC

为元素设置以下属性即可创建一个新的BFC

  float: left|right;
  overflow: hidden|auto|scroll;
  display: table-cell|table-caption|inline-block;
  position: absolute|fixed;
  • BFC特性:
  1. 阻止垂直外边距折叠:让嵌套的元素分别在不同的BFC就可以阻止它们外边距折叠。
  2. BFC不会重叠浮动元素
  3. BFC可以包含浮动,可以利用这一条特性来清除浮动,设置父元素为BFC,就可以清除浮动,但是这样做都会有一些负作用,要根据实际情况选择不同的方式。
  • BFC作用:
  1. 解决margin重叠问题,同一个BFC中,相邻元素之间的边距会合并,如果把这两个元素分别放在两个BFC中,他们的边距就不会合并。一般应用于嵌套。
  2. 清除浮动。BFC不会重叠浮动元素。

在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例

  • 两个在普通文档流中相邻的元素外边距相遇的时候发生合并。这个相邻可以是父子关系相邻,兄弟关系相邻,一个元素内部没有东西,自身的上下边距相遇时也会发生外边距合并。只有普通文档流中块级元素的垂直外边距才会发生外边距合并。内联元素、浮动元素或绝对定位元素之间的外边距不会合并。

  • 如何合并
    会选取较大值进行合并
    合并的结果: 两个外边距都是正数,取两者之中的较大者;两个外边距都是负数,取两者之间绝对值较大者;当两个外边距一正一负时,取两者的和。

  • 不让相邻元素外边距合并的方法:

  1. 被非空内容、padding、border 或 clear 分隔开。
  2. 不在一个普通流中或一个BFC中。
  3. margin在垂直方向上不毗邻。

下面就是父子元素外边距的重叠效果,wrapper(父级元素)的外边距与content(子级元素)的外边距重叠


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容

  • 一、浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 特征:1、浮动模型是一种可视化格式...
    青鸣阅读 955评论 0 0
  • 浮动元素的特征 浮动元素的框可以左右移动(根据float属性的值而定),直到它的外边框碰到包含框或者另一个浮动元素...
    倾国倾城的小饼干阅读 427评论 0 0
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,727评论 1 92
  • 浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 4.对普通元素:普通元素将不能感知到浮...
    l_meng阅读 300评论 0 0
  • 和女朋友在旅行中发生争吵,她赌气离去,此时你会发一条怎样的短信挽回她?面对这个问题,相信很多男生的做法都和刘宪华的...
    殇永阅读 606评论 0 3