二.弹性布局(重点******************************************)

1.什么是弹性布局

弹性布局,是一种布局方式。

主要解决的是某个元素中子元素的布局方式

让页面布局更加的灵活

2.弹性布局专有的名词解释

1.容器

要发生弹性布局的子元素,他们的父元素,成为容器

就是设置display:flex的那个元素

2.项目

要发生弹性布局的子元素们,叫项目

就是设置了display:flex的元素的子元素们

3.主轴

项目们排列方向的一根轴,称之为主轴

如果项目们是按照水平排列,那么主轴就是x轴

如果项目们按照垂直排列,那么主轴就是y轴

项目们在主轴排列的顺序,称为主轴起点和主轴的终点

4.交叉轴

与主轴垂直的一根轴,叫做交叉轴

项目们在交叉轴的排列顺序,称为交叉轴的起点和终点

3.语法

将元素设置为弹性容器之后,他所有的子元素,都会变为弹性项目

display:flex;  将块级元素设置为容器

inline-flex 将行内元素设置为容器

注意:

元素设置为flex容器后,容器的text-align,vertical-align失效

项目float,clear失效

4.容器的属性

①设置主轴的方向

flex-direction

取值  row 默认值,主轴是x轴,主轴起点在左端

row-reverse 主轴是x轴,主轴起点在右端

column     主轴是y轴,主轴起点在顶部

column-reverse 主轴是y轴,主轴起点在底部

②设置项目的换行

flex-wrap:

取值: 默认值  nowrap  空间不够时,不换行,项目会自动缩小

wrap  空间不够时,项目不缩小,换行

wrap-reverse 项目换行,并反转

③上面两个属性的简写

flex-flow:direction wrap;

④定义项目在主轴上的对齐方式

justify-content

取值 1.flex-start 默认值,主轴起点对齐

2.flex-end 主轴终点

3.center   主轴中心

4.space-around 每个外边距相同,两端有空白

5.space-between 两端对齐,两端无空白

5.项目们在交叉轴上的对齐方式

align-items:

取值

1.flex-start 默认值,交叉轴起点对齐

2.flex-end 交叉轴终点对齐

3.center 交叉轴中间对齐

4.baseline 基线,同flex-start类似

5.stretch 项目不写高,充满容器整个高度

5.项目属性

设置在项目中的属性,只会影响当前项目

不影响其他项目

①项目顺序

order 定义项目排列的顺序,值越小。越靠近起点。默认值为0

取值:无单位数字

②flex-grow

如果容器有足够大的剩余空间,项目将按比例放大(比例不准确)

取值,无单位数字   默认值 0

③flex-shrink

如果容器空间不够,项目将按比例缩小(比例不准确)

取值,无单位数字   默认值 1   取值越大,缩小的越快

④align-self

定义某一个项目在交叉轴上的对齐方式,不影响其他项目

取值

1.flex-start交叉轴起点对齐

2.flex-end 交叉轴终点对齐

3.center 交叉轴中间对齐

4.baseline 基线,同flex-start类似

5.stretch 项目不写高,充满容器整个高度

6.auto 使用align-items定义的值

三.css hack

由于不同的浏览器对css的解析认知是不同的,会导致同一份css在不同的浏览器生成的页面效果不同

我们要针对不同的浏览器写不同的css代码

这种写不同css代码的过程,就叫css hack

tmooc有相关的视频

-webkit-

-ms-

-moz-

-o-

四.转换(重点******)

1.什么是转换

改变元素在页面中的位置,大小,角度,形状

2D转换,只在x轴和y轴上发生转换

3D转换,增加了z轴的转换效果

2.转换属性

transform:

取值:1.none 默认值,无任何转换效果

2.转换函数 transform-function

转换函数 transform-function:位移,旋转,放大,倾斜,3D旋转

3.转换原点

transform-origin:

转换原点会影响元素旋转时的效果

取值:1.以px为单位的数字

2.%

3.关键字   left/center/right   top/center/bottom

4.2D转换

①位移

transform:translate();

取值 1.translate(x) 和 translateX(x)

x轴位移  + 往右    - 往左

2.translateY(y)

y轴位移  + 往下    - 往上

3.translate(x,y) 同时设置x轴和y轴的位移

②缩放

③旋转

④倾斜

css3弹性布局的更多相关文章

  1. 【repost】CSS3弹性布局

    本文导读:在CSS 3中,CSS Flexible Box模块为一个非常重要的模块,该模块用于以非常灵活的方式实现页面布局处理.使用CSS Flexible Box模块中定义的弹性盒布局技术,可以根据 ...

  2. css3弹性布局语法全解

    本文介绍css3弹性布局的语法 html布局 <div class="box"> <div class="item">1</div ...

  3. css3 弹性布局和多列布局

    弹性盒子基础 弹性盒子(Flexible Box)是css3中盒子模型的弹性布局,在传统的布局方式上增加了很多灵活性. 定义一个弹性盒子 在父盒子上定义display属性: #box{ display ...

  4. 从零开始学习前端开发 — 12、CSS3弹性布局

    一.分栏布局 1.设置栏数column-count:数值; 2.设置每栏的宽度column-width:数值+单位; 注:当设置了column-width,column-count会失效,二者设置其一 ...

  5. CSS3弹性布局内容对齐(justify-content)属性使用具体解释

    内容对齐(justify-content)属性应用在弹性容器上.把弹性项沿着弹性容器的主轴线(main axis)对齐. 该操作发生在弹性长度以及自己主动边距被确定后. 它用来在存在剩余空间时怎样加以 ...

  6. CSS3弹性布局内容对齐(justify-content)属性使用详解

    内容对齐(justify-content)属性应用在弹性容器上,把弹性项沿着弹性容器的主轴线(main axis)对齐. 该操作发生在弹性长度以及自动边距被确定后. 它用来在存在剩余空间时如何加以分配 ...

  7. css3 FlexBox 弹性布局

    Flex 弹性布局 这个是css3中新添加的内容,现在已经支持所有的浏览器,利用Flex布局,可以简便.完整.响应式地实现各种页面布局. 注意:在设置 flex 后,子元素的flaot ,clear, ...

  8. CSS3支持box-flex弹性布局

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...

  9. 第 29 章 CSS3 弹性伸缩布局[上]

    学习要点: 1.布局简介 2.旧版本 主讲教师:李炎恢 本章主要探讨 HTML5 中 CSS3 提供的用来实现未来响应式弹性伸缩布局方案,这里做一个初步的了解. 一.布局简介 CSS3 提供一种崭新的 ...

随机推荐

  1. js之用IndexOf返回指定字符串的次数

    代码 var Str = "strs,strs,stras,str,strs,strs"; var subStr ="strs" ; var count = 0 ...

  2. docker中安装nginx,部署前端代码

    最近在学习docker,初次接触,难免遇到磕磕碰碰,遂将其整理成博客,以便日后查看. 1.拉取nginx镜像 直接从官方镜像库拉取简单粗暴: docker pull nginx 2.运行 docker ...

  3. mysql不同端口的连接

    连接mysql3306端口命令 mysql -h58.64.217.120 -ushop -p123456 连接非3306端口(指定其他端口) 的命令 mysql -h58.64.217.120 -P ...

  4. Netty(二):数据在ChannelPipeline中的流经

    本文目的:测试数据在ChannelPipeline中的流经顺序及状态. 先看本文的测试代码: AdditionalInBoundHandler:入站处理器,不做任何处理,只是在响应读事件时打印用来观察 ...

  5. Bind+DLZ+MySQL智能DNS的正向解析和反向解析实现方法

    使用文本配置文件的配置方式结合bind的最新的acl和view特性来实现智能DNS想必很多人已经很熟悉了,使用MySQL数据库来存放zone文件的方式可能也不少.对于两者都熟悉的,实现 Bind+DL ...

  6. C++入门编程题目 NO.1

    题目:有1.2.3.4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 1.程序分析:可填在百位.十位.个位的数字都是1.2.3.4.组成所有的排列后再去 掉不满足条件的排列. #incl ...

  7. 疯子的算法总结(九) 图论中的矩阵应用 Part 2 矩阵树 基尔霍夫矩阵定理 生成树计数 Matrix-Tree

    定理: 1.设G为无向图,设矩阵D为图G的度矩阵,设C为图G的邻接矩阵. 2.对于矩阵D,D[i][j]当 i!=j 时,是一条边,对于一条边而言无度可言为0,当i==j时表示一点,代表点i的度. 即 ...

  8. 信息奥赛一本通1486: CH 6202 黑暗城堡 最短路径生成树计数

    1486:黑暗城堡 [题目描述] 知道黑暗城堡有 N 个房间,M 条可以制造的双向通道,以及每条通道的长度. 城堡是树形的并且满足下面的条件: 设 Di为如果所有的通道都被修建,第 i 号房间与第 1 ...

  9. 一只简单的网络爬虫(基于linux C/C++)————socket相关及HTTP

    socket相关 建立连接 网络通信中少不了socket,该爬虫没有使用现成的一些库,而是自己封装了socket的相关操作,因为爬虫属于客户端,建立套接字和发起连接都封装在build_connect中 ...

  10. 从零开始通过webhooks实现前端自动化

    1. 前置条件 有一台自己的服务器.比如阿里云,腾讯云之类 有远程仓库能够push代码,pull代码.比如github,或者码云 远程仓库有webhooks功能 2. 自动化部署流程 3. 构建流程 ...