一、分栏布局

1.设置栏数column-count:数值;

2.设置每栏的宽度column-width:数值+单位;

注:当设置了column-width,column-count会失效,二者设置其一即可

3.设置栏间距column-gap:数值+单位;

4.设置栏间隔线column-rule:5px solid|dashed|dotted black;

5.设置是否跨栏显示column-span:all(跨栏)|none(不跨栏);

注:a)给需要跨栏显示的元素设置该属性

b) 该属性只有chrome浏览器支持


二、弹性布局

说明:

(1) 当给元素设置了display:flex;后,该元素就成为了弹性盒

(2) 当父元素设置了display:flex;后,子元素的float,clear,vertical-align将会失效

(3) 我们将设置display:flex;属性的父元素称为flex容器,里面所有的子元素称为容器成员或flex项目

(4) 当设置了display:flex;后会随之产生两根轴线:主轴和交叉轴

Flex容器属性

1.设置主轴方向语法: flex-direction:row|row-reverse|column|column-reverse;

row 默认值,主轴在水平方向,起点在左端

row-reverse 主轴在水平方向,起点在右端

column 主轴在垂直方向,起点在上沿

column-reverse 主轴在垂直方向,起点在下沿

2.设置flex容器是单行显示还是多行显示语法: flex-wrap:nowrap|wrap|wrap-reverse;

nowrap 默认值,不换行

wrap 换行

wrap-reverse 换行,但行的顺序会倒过来

注:该属性主要针对主轴在水平方向上的时候

3.flex-flow是flex-direction和flex-wrap的简写方式默认值为:flex-flow:row nowrap;

4.设置主轴的对齐方式语法: justify-content:flex-start | flex-end | center | space-between | space-around;

a)flex-start 默认值,类似于左浮动

b)flex-end 类似于右浮动

c)center 居中对齐

d)space-between flex项目两端对齐,中间间隔相等

e)space-around flex项目两侧的间隔相等

5.设置交叉轴对齐方式align-items:flex-start|flex-end|center|baseline|stretch;

a) flex-start 对齐交叉轴的起点

b) flex-end 对齐交叉轴的终点

c) center 沿交叉轴方向居中对齐

d) baseline 沿flex项目第一行文字基线对齐

e) stretch 当flex项目没有设置高度或为auto时,将占满整个父元素的高度

注:使用弹性盒如何实现不定宽高元素在父元素中水平垂直都居中

方法如下:

父元素{

display:flex;
justify-content:center;
align-items:center;
}

如何使元素在屏幕窗口水平垂直都居中,设置如下:

html,body{height:100%;}

body{

display:flex;
justify-content:center;
align-items:center;
}

6.设置多根轴线的对齐方式: align-content:flex-start|flex-end|center|space-between|space-around|stretch;

a) flex-start 对齐交叉轴的起点

b) flex-end 对齐交叉轴的终点

c) center 以交叉轴为参考,居中对齐

d) space-between 多根轴线两端对齐,轴线之间间隔相等

e) space-around 轴线两侧的间隔相等

f) stretch 如果flex项目没有设置高度或为auto,将会均分父元素的高度

注: 当只有一根轴线时,此属性不起作用

Flex项目属性

1.设置flex项目的排列顺序order:数值; (值越小越靠前)

2.设置某个flex项目不同于其他flex项目的交叉轴对齐方式(重写父元素的align-items属性): align-self:flex-start|flex-end|center|baseline|stretch;

3.设置flex项目的放大比例: flex-grow:0 | 数值;

注:当父元素存在剩余空间时,默认值为0,不放大

4.设置flex项目的缩小比例: flex-shrink:1|数值;

注:当父元素空间不足时,默认flex项目等比例缩小,flex-shrink默认值为1

flex-shrink:0; 即使父元素空间不足,flex项目也不缩小

5.设置flex项目占据主轴的空间flex-basis:数值+单位;

注:类似于给元素设置宽高;

6.flex属性是flex-grow,flex-shrink,flex-basis的简写方式默认值: flex:0 1 auto;

flex:1;的两个应用

a) 等比例分配空间

b) 分配剩余空间

从零开始学习前端开发 — 12、CSS3弹性布局的更多相关文章

  1. 从零开始学习前端开发 — 6、CSS布局模型

    一.css布局模型 1.流动模型(Flow) 元素在不设置css样式时的布局模型,是块元素就独占一行,是内联元素就在一行逐个进行显示 2.浮动模型(Float) 使用float属性来进行网页布局,给元 ...

  2. 从零开始学习前端开发 — 11、CSS3选择器

    一.基本选择器 1.* 通配符(通用选择器) 2.id选择器 3.class选择器(类选择器) 4.标签选择器(元素选择符) 5.群组选择器 (选择符1,选择符2{...}) 二.层次选择器(关系选择 ...

  3. 从零开始学习前端开发 — 17、CSS3背景与渐变

    一.css3背景切割: background-clip:border-box|padding-box|content-box; 作用: 用来设置背景的可见区域 a) border-box 默认值,背景 ...

  4. 从零开始学习前端开发 — 16、CSS3圆角与阴影

    一.css3圆角: border-radius:数值+单位; 1.设置一个值:border-radius:20px; 四个方向圆角都为20px(水平半径和垂直半径相等) 2.设置两个值 border- ...

  5. 从零开始学习前端开发 — 15、CSS3过渡、动画

    一.css3过渡 语法: transition: 过渡属性 过渡时间 延迟时间 过渡方式; 1.过渡属性(transition-property) 取值:all 所有发生变化的css属性都添加过渡 e ...

  6. 从零开始学习前端开发 — 14、CSS3变形基础

    一.css3变形: transform:rotate(旋转)|scale(缩放)|skew(倾斜)|translate(位移); 注:当多种变形方式综合在一起时,用空格隔开 1.旋转 a) rotat ...

  7. 从零开始学习前端开发 — 1、HTML基础

    一.web标准 web标准-网页制作的标准,它是由一系列标准组成的,主要包含三个方面:结构(html,xhtml),表现(css),行为(javascript) 注:结构和表现的标准由w3c(万维网联 ...

  8. 从零开始学习前端开发 — 18、BFC

    一. BFC的概念 BFC--block formating context的缩写,中文译为"块级格式化上下文" 二.如何触发BFC 1.设置float除none以外的值(left ...

  9. 从零开始学习前端开发 — 2、CSS基础

    一.CSS简介  1.CSS是什么 CSS是Cascading Style Sheets的简称,中文称为层叠样式表.特点:实现了表现与结构相分离 2.css基础语法 css是由选择符和声明两大部分组成 ...

随机推荐

  1. Java企业微信开发_11_异常:java.net.UnknownHostException: qyapi.weixin.qq.com

    原因: 网络原因导致 dns解析失败. 解决方案: 方案一 : 1.查看你的服务器能否ping通外网,不过不行说明你的网络出了问题.     (我的情况是客户的应用服务器只能内网访问,所以是网络出问题 ...

  2. vue监听scroll使用报错的解决办法

    错误说明:在切换路由以后,依旧在其他页面触发了scroll有关的函数, 错误原因:在spa项目中,window对象是不变的,所以每次使用后需要销毁. 解决办法:vue的生命周期destroyed中销毁 ...

  3. Struts2-整理笔记(五)拦截器、拦截器配置

    拦截器(Interceptor) 拦截器是Struts2最强大的特性之一,它是一种可以让用户在Action执行之前和Result执行之后进行一些功能处理的机制. 拦截器的优点 简化了Action的实现 ...

  4. VS代码生成工具ReSharper使用手册:配置快捷键(转)

    原文:http://blog.csdn.net/fhzh520/article/details/46364603 VS代码生成工具ReSharper提供了丰富的快捷键,可以极大地提高你的开发效率. 配 ...

  5. ASP.NET Core学习之三 NLog日志

    上一篇简单介绍了日志的使用方法,也仅仅是用来做下学习,更何况只能在console输出. NLog已是日志库的一员大佬,使用也简单方便,本文介绍的环境是居于.NET CORE 2.0 ,目前的版本也只有 ...

  6. 使用MethodType函数将方法绑定到类或实例上

    在开始正文之前,需要了解下Python的绑定方法(bound method)和非绑定方法. 简单做个测试: 定义一个类,类中由实例方法.静态方法和类方法. class ClassA: def inst ...

  7. NOTIC: Invalid argument supplied for foreach()

    NOTIC: [2] Invalid argument supplied for foreach() Warning: Invalid argument supplied for foreach() ...

  8. Java学习笔记11---静态成员变量、静态代码块、成员变量及构造方法的初始化或调用顺序

    当创建一个对象时,各种成员变量及构造方法的初始化或调用顺序是怎样的呢? (1).如果类尚未加载,则先初始化静态成员变量和静态代码块,再初始化成员变量,最后调用相应的构造方法: (2).如果类已经加载过 ...

  9. docker:(4)利用WebHook实现持续集成

    研发小伙伴可能对下列操作步骤会深有体会 写代码-->提交代码-->打包-->发布 在项目调试测试阶段,可能经常需要重复上面的步骤,以便将最新代码部署到特定环境供测试人员或其他人员使用 ...

  10. Google mobile test

    1. 现已更新至3.0+版本: 2. 应对版本频繁的迭代更新,进行[版本监控.持续更新.反馈,开发的单元测试] 1. 多关注金字塔的底层: 2. [集成测试, Espresso, EarlGrey] ...