从零开始学习前端开发 — 12、CSS3弹性布局
一、分栏布局
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弹性布局的更多相关文章
- 从零开始学习前端开发 — 6、CSS布局模型
一.css布局模型 1.流动模型(Flow) 元素在不设置css样式时的布局模型,是块元素就独占一行,是内联元素就在一行逐个进行显示 2.浮动模型(Float) 使用float属性来进行网页布局,给元 ...
- 从零开始学习前端开发 — 11、CSS3选择器
一.基本选择器 1.* 通配符(通用选择器) 2.id选择器 3.class选择器(类选择器) 4.标签选择器(元素选择符) 5.群组选择器 (选择符1,选择符2{...}) 二.层次选择器(关系选择 ...
- 从零开始学习前端开发 — 17、CSS3背景与渐变
一.css3背景切割: background-clip:border-box|padding-box|content-box; 作用: 用来设置背景的可见区域 a) border-box 默认值,背景 ...
- 从零开始学习前端开发 — 16、CSS3圆角与阴影
一.css3圆角: border-radius:数值+单位; 1.设置一个值:border-radius:20px; 四个方向圆角都为20px(水平半径和垂直半径相等) 2.设置两个值 border- ...
- 从零开始学习前端开发 — 15、CSS3过渡、动画
一.css3过渡 语法: transition: 过渡属性 过渡时间 延迟时间 过渡方式; 1.过渡属性(transition-property) 取值:all 所有发生变化的css属性都添加过渡 e ...
- 从零开始学习前端开发 — 14、CSS3变形基础
一.css3变形: transform:rotate(旋转)|scale(缩放)|skew(倾斜)|translate(位移); 注:当多种变形方式综合在一起时,用空格隔开 1.旋转 a) rotat ...
- 从零开始学习前端开发 — 1、HTML基础
一.web标准 web标准-网页制作的标准,它是由一系列标准组成的,主要包含三个方面:结构(html,xhtml),表现(css),行为(javascript) 注:结构和表现的标准由w3c(万维网联 ...
- 从零开始学习前端开发 — 18、BFC
一. BFC的概念 BFC--block formating context的缩写,中文译为"块级格式化上下文" 二.如何触发BFC 1.设置float除none以外的值(left ...
- 从零开始学习前端开发 — 2、CSS基础
一.CSS简介 1.CSS是什么 CSS是Cascading Style Sheets的简称,中文称为层叠样式表.特点:实现了表现与结构相分离 2.css基础语法 css是由选择符和声明两大部分组成 ...
随机推荐
- Nginx (三) 使用Keepalived搭建高可用服务
Nginx可以实现高并发反向代理,实现负载均衡,但是有个问题就是Nginx是单点的.如果Nginx故障,则整个服务将会处于不可用状态.所以我们就需要想办法让nginx高可用,即使一个Nginx宕机,还 ...
- Codebase Refactoring (with help from Go)
Codebase Refactoring (with help from Go) 代码库重构(借助于Go) 1.摘要 Go应该添加为类型创建替代等效名称的能力,以便在代码库重构期间渐进代码修复.本文解 ...
- Xamarin 简单的网络请求
//try //{ // var httpReq = (HttpWebRequest)HttpWebRequest.Create(new Uri(re ...
- Java中对List<E>按E的属性排序的简单方法
这是LeetCode上的题目56. Merge Intervals中需要用到的, 简单来说,定义了E为 /** * Definition for an interval. * public class ...
- ASP.NET MVC 5使用Swagger生成API文档
一.安装 新建一个没有身份验证的mvc项目 - SwaggerMvc5Demo,然后添加一个名为Remote(自定义)且包含基础读写(不想手写)的ApiController 开源地址:https: ...
- Fiddler工具的界面说明
1.Fiddler界面说明 2.session的模块说明 包含部分如下: 注:标蓝色区域的内容为平时较常用的部分 3.session不同图标和不同颜色的含义 默认颜色的含义如下: 部分图标的含义如下: ...
- PHP 微信公众号-创建菜单-配置
1.服务号 2.基本配置 注意: URL: 确保能访问到你对应的文件 Token:随意设置,但是要与文件里的一致 3.网页授权 注意:填写网站域名 4.更具实际需求创建菜单
- 我的Python学习笔记(二):浅拷贝和深拷贝
在Python中,对象赋值,拷贝(浅拷贝和深拷贝)之间是有差异的,我们通过下列代码来介绍其区别 一.对象赋值 对象赋值不会复制对象,它只会复制一个对象引用,不会开辟新的内存空间 如下例所示,将test ...
- linux下vsftpd的安装及配置使用详细步骤
vsftpd 是“very secure FTP daemon”的缩写,安全性是它的一个最大的特点. vsftpd 是一个 UNIX 类操作系统上运行的服务器的名字,它可以运行在诸如 Linux.BS ...
- chrome调试工具高级不完整使用指南(实战一)
三.chrome调试工具实战 3.1 获取界面对应的HTML和修改样式 我们以博客园为例子来分析. 通过上面的操作就可以定位到对应的HTML代码 左侧菜单显示的就是当前指定元素层叠样式的一个情况 上面 ...