一、概述

    1、什么是定位体系

    视觉格式化模型规定,定位体系共有三种

            a.常规流(normal flow)

            b.浮动(float)

            c.绝对定位(absolute posotioned)

    任何一个元素,必须属于其中一种定位系统

二、定位体系判定

    

三、盒模型和定位体系

1、盒模型=盒子体系

    定位体系=盒子位置

2、盒模型中的尺寸

  • margin:px、em、%、auto
  • border:px、em
  • padding:px、em、%、auto
  • height:px、em、%、auto

px、em:1em=10px(盒子中的字体大小为10px)

%:尺寸是包含快尺寸的百分比,margin、padding、width的百分比是宽度的百分比

auto:尺寸受到定位体系的规则

3、常规流

    又叫普通流、文档流、普通文档器,是最常见的,默认状态下的定位

     a.常规流块盒水平方向上的居中(常用)

            step1 给块盒设宽度

                水平方向的尺寸,必须等于包含快的宽度

            step2 给块盒margin设置 :0 auto

     b.垂直方向上居中

            若两个外边距相邻,则进行合并(折叠)

            合并:

  • 两个包含块均为正值,则取最大的值
  • 两个包含块均为负值,则取最小的值
  • 两个包含块一正一负,则取两个值相加

            注:水平方向的外边距不会合并

4、浮动 float

        取值:float:right/left;

        清浮动,即,找回父级的高度

    

5、flex 弹性盒子

        display:flex;(在容器内增添)

        分为:容器(父元素) 项目(子元素)

    (1)容器的属性:

  • direction 控制子元素的方向(行、列)

                    flex-direction:row;主轴为水平方向,子元素从左到右排列,为默认值

                    flex-direction:row-reverse;主轴为水平方向,子元素从右到左排列

                    flex-direction:colum;主轴为垂直方向,子元素从上到下排列

                    flex-direction:colum-reverse;主轴为水平方向,子元素从下到上排列

  • wrap 换行

                    flex-wrap:nowrap;不换行,为默认值

                    flex-wrap:wrap;换行,第一行在上方

                    flex-wrap:wrap-reverse;换行,第一行在下方

  • justify-content 主轴方向对齐方式

                    justify-content:center;主轴方向居中

                    justify-content:flex-end;主轴结束位置flex-end对齐

                    justify-content:flex-start;主轴起始位置flex-start对齐

                    justify-content:space-between;两端对齐,

                     即第一个项目在容器的起始位置,最后一个项目在容器的结束位置。

                    justify-content:space-around;分散对齐

                    (计算公式: (剩余空间 / 项目个数)/2得到的结果,就是每个项目的左右距离。)

                    justify-content:space-evenly;平均分散对齐

                     每个项目之间的距离相同,即平分剩余空间

                <space 对剩余空间的分配方式,剩余空间 = 容器的尺寸 - 项目尺寸之和>

  • align 交叉轴方向对齐方式

                    一根主轴(itmes):

                        align-items: flex-start;交叉轴起始位置flex-start对齐

                        align-items: flex-end;交叉轴结束位置flex-end对齐

                        align-items: center;交叉轴居中对齐

                        align-items: baseline;交叉轴基线对齐

                    多跟主轴(content):

                        项目在开通换行后

                        align-content: flex-start;交叉轴起始位置flex-start对齐

                        align-content: flex-end;交叉轴结束位置flex-end对齐

                        align-content: center;交叉轴居中对齐

                        align-content: space-between;交叉轴起始和结束位置对其(上下两端对其)

                        align-content: space-around;交叉轴分散对齐

                (当容器交叉的尺寸大于各项目尺寸之和,才需要进行对齐方式的设置。)

    (2)项目的属性

                order 定义项目排列顺序,数值越小,排列越靠前,默认值为0

                flex-grow 定义项目的放大比例,默认为0,即,即使有剩余空间也不放大

                    若设值为>0,则,将按照设值的数值比例分配剩余空间

                flex-shrink 定义项目的缩小比例,默认为1,即,如果空间不足,则将项目按比例缩小

                    若一个项目为0,其余为1,则,空间不足时前者不缩小

                flex-basis 定义分派多余空间前,项目占据的主轴空间,默认为0,即,项目本来大小

                align-self 允许单个项目与其他项目不一样的对齐方式,可覆盖 align-items的属性,默认值为auto

                    表示继承父元素align-items的属性

                flex属性是这三多的缩写

                    默认值:0 1 auto;

                    快捷键

                        auto(1 1 auto)

                        none(0 0 auto)

             flex-flow,属性是flex-direction和flex-wrap属性的简写

                    默认值为 :row nowrap;

6、绝对定位

    (1)相对位置

position:relative

            相当于盒子在原本定位体系下的位置,移动后会保留原来的位置,不影响其他元素的位置

                属于常规流

            将盒子的position属性设为relative 以启用相对位置

    (2)固定位置

            position:fixed;

  • 概念:

                    1、脱离文档流(不占位置)

                     2、宽度为auto(内容的宽)

                     3、方向值 top:。。。(不给方向值,原来在什么位置,就在什么位置)

  • 包含块:是视口的起始点(0,0),左上角
  • 使用场景

                    1、AD(广告)

                    2、导航、页角

                    3、遮罩层(页面弹窗)

  • 堆叠级别

                    默认值为0;

                    取值5以内

    (3)绝对位置

            position:absolute;

  • 概念

                     1、脱离文档流(不占位置)

                     2、宽度为auto(内容的宽)

                     3、方向值(不给方向值,原来在什么位置,就在什么位置)

                     4、包含块position推荐取(relative)

  • 包含块

                    看父级的position是否为static,不是则该父级为包含块

  • 适用场景

                     当多个标签需要重叠展示时

CSS中的定位体系的更多相关文章

  1. CSS中的定位与浮动

    CSS中的定位与浮动 本文主要讲述CSS中的三种定位样式static.relative和absolute的区别以及浮动元素的特征. 定位样式 CSS中定位样式position的取值有三个,默认值:st ...

  2. 关于CSS中的定位使用子绝父相(子类绝对位置和父类相对位置)

    关于CSS中的定位使用子绝父相(子类绝对位置和父类相对位置) 欢迎转发,但是请填写原博客地址https://www.cnblogs.com/JNovice/p/9536910.html  前言:最近在 ...

  3. css中的定位属性position(转)

    css中的定位属性position   同样的也是上课的时候发现学生难以理解的一些问题拿出来记录一下,希望帮助初学者. 在css中定位属性position的运用在页面中是很常用的,特别是一些结合js来 ...

  4. 总结一下CSS中的定位 Position 属性

    在CSS中,Position 属性经常会用到,主要是绝对定位和相对定位,简单的使用都没有问题,尤其嵌套起来,就会有些混乱,今记录总结一下,防止久而忘之. CSS position 属性值: absol ...

  5. [转]总结一下CSS中的定位 Position 属性

    在CSS中,Position 属性经常会用到,主要是绝对定位和相对定位,简单的使用都没有问题,尤其嵌套起来,就会有些混乱,今记录总结一下,防止久而忘之. CSS position 属性值: absol ...

  6. CSS中的定位机制

    CSS3 中有三种定位机制 : 普通文档流 (text)| 浮动(float) | 定位(position) 普通文档流 就是CSS中默认的文本文档 普通流中,元素位置由文档顺序和元素性质决定,块级元 ...

  7. css中元素定位

    在html中网页可以看成一个立体的空间,一个完整的页面是由很多个页面堆积形成的,如下图所示 CSS中Position属性有四个可选值,它们分别是:static.absolute.fixed.relat ...

  8. css中的定位

    上一篇博客,我大概介绍了下浮动的使用及行为.其实在整个文档布局中,定位也对我们整个的页面排版有非常好的帮助,当然前提是使用得当. 一.定位分类: a.静态定位  position:static;   ...

  9. 对css中的定位属性postion刨根解牛

    定位的基本思想很简单: 它允许你定义元素框相对于其正常位置应该出现的位置(relative),或者相对于父元素(absolute).另一个元素甚至浏览器窗口本身的位置(fixed).显然,这个功能非常 ...

随机推荐

  1. 2018 CCPC 吉林站 H Lovers

    2018 CCPC 吉林站 H Lovers 传送门:https://www.spoj.com/problems/LIS2/en/ 题意: q次操作 1.将第l~r个数的左边和和右边都加上一个数d, ...

  2. P3810 陌上花开 CDQ分治

    陌上花开 CDQ分治 传送门:https://www.luogu.org/problemnew/show/P3810 题意: \[ 有n 个元素,第 i 个元素有 a_i. b_i. c_i 三个属性 ...

  3. 默认 Servlet

    什么是 DefaultSevelet DefaultSevelet 是处理静态资源的 Sevelet. 在什么位置声明它? 它在 $CATALINA_HOME/conf/web.xml 中被全局声明. ...

  4. HDU 2899 Strange fuction [二分]

    1.题意:给一个函数F(X)的表达式,求其最值,自变量定义域为0到100 2.分析:写出题面函数的导函数的表达式,二分求导函数的零点,对应的就是极值点 3.代码: # include <iost ...

  5. visio基础

    右下角是一个切换文件的按钮 也可以用ctrl+tab键进行切换 页面底部左边是一个页面的增加与切换的几个按钮 这是切换页面不是切换文件 右上角这个按钮是一个功能隐藏的按钮 左上角这个按钮可以自定义快速 ...

  6. nginx和keeplive实现负载均衡高可用

    一. Keeplive服务介绍 Keeplive期初是专门为LVS设计的,专门用来监控LVS集群系统中各个服务节点的状态,后来又加入VRRP的功能,因此除了配合LVS服务以外,也可以作为其他服务(ng ...

  7. SpringBoot系列之自定义starter实践教程

    SpringBoot系列之自定义starter实践教程 Springboot是有提供了很多starter的,starter翻译过来可以理解为场景启动器,所谓场景启动器配置了自动配置等等对应业务模块的一 ...

  8. Mysql 字段类型与约束条件

    一.数值类型 二.日期类型 三.枚举与集合 四.约束条件 五.设置严格模式 一.数值类型 1.1 整型 应用场景: id号.年龄... tinyint: 有符号:默认范围 -128, 127 无符号: ...

  9. echart环形图制作及出现的一些问题总结

    环形图的形成其实就是echarts中的饼图pie,控制饼图的内圈半径和外圈半径来形成环形的效果!下面记录的问题是在开发中出现发现的,因为在网上找到了利用阴影来做下面的图: 说明: 由于代码比较长,不能 ...

  10. 一文MyBatis-Plus快速入门

    目录 一.依赖及配置 1.在idea中创建一个SpringBoot项目,在pom.xml中添需要的依赖 2.配置数据库连接 3.在启动类中添加注解 @MapperScan 扫描Mapper接口包 4. ...