码迷,mamicode.com
首页 > 其他好文 > 详细

布局md

时间:2018-09-26 22:09:01      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:otto   绝对定位   auto   hidden   text   ext   splay   窗口   min   

高级布局

一、文档流(normal flow)

1、概念

本质为normal flow(普通流、常规流)将窗体自上而下分成一行一行,块级元素从上至下、行内元素在每行中从左至右的顺序依次排放元素。
v_hint:本质不存在文档流概念,当一个错误的概念被绝大数人认为是对的,那么它就是对的

2、BFC(Block formatting context)

块级格式化上下文,它是一个独立的渲染区域,只有Block-level box参与,它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干。

3、BFC规则

① 内部的Box会在垂直方向,一个接一个地放置;
② Box自身垂直方向的位置由margin-top决定,属于同一个BFC的两个相邻Box的margin会发生重叠;
③ Box自身水平方向的位置由margin左或右决定(具体已经参照BFC方位),属于同一个BFC的两个相邻Box的margin会发生叠加。

二、浮动布局

1、解决的经典案例

<style type="text/css">
    .box {
        width: 300px;
        border: 1px solid black;
    }
    .box img {
        width: 150px;
        float: left;
    }
</style>
<div class="box">
    <img src="bg.gif" >
    浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布     局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决     的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典     案例,浮动布局解决的经典案例,浮动布局解决的经典案例,浮动布局解决的经典案例。
</div>

2、基本语法

float: left | right

3、浮动布局问题

  • 在不做清浮动情况下,父级不会获取子级的高度

4、清浮动

  • 目的:对父级所在容器中的Block-level Box布局不产生影响
  • 原理:在浮动布局情况下,让父级获得合适的高度
① 浮动的父级设置高度
super {
    height: npx;
}
② 浮动的父级设置overflow
super {
    overflow: hidden;
}
③ 浮动的父级兄弟设置clear
brother {
    clear: left | right | both;
}
④ 浮动的父级伪类清浮动
super:after {
    content: "";
    display: block;
    clear: left | right | both;
}

三、流式布局

1、解决的经典案例

<style type="text/css">
    .wrap {
        max-width: 1200px;
        min-width: 800px;
        width: 90%;
        height: 600px;
        margin: 0 auto;
        background-color: orange;
    }
</style>
<div class="wrap"></div>

2、流式布局相关操作

① 百分比设置 %
② 窗口比设置 vw | vh
③ 字体控制 em | rem

四、定位布局

1、解决的经典案例

<style type="text/css">
    .ad {
        width: 150px;
        height: 320px;
        background-color: orange;
        position: fixed;
        top: calc(50vh - 160px);
        left: 0;
    }
</style>
<div class="ad"></div>
br*100

2、定位的语法

position: static | relative | absolute | fixed
布局方位:left | right | top | bottom

3、相当定位(relative)

① 未脱离文档流
② 以自身原有位置作为参考坐标系

4、绝对定位(absolute)

① 脱离文档流
② 以最近定位父级作为参考坐标系

5、固定定位(fixed)

① 脱离文档流
② 以文档窗口作为参考坐标系

6、z-index

布局md

标签:otto   绝对定位   auto   hidden   text   ext   splay   窗口   min   

原文地址:https://www.cnblogs.com/layerluo/p/9709945.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!