CSS弹性盒子(详细版,建议收藏)

33,654次阅读
没有评论

共计 4094 个字符,预计需要花费 11 分钟才能阅读完成。

一、弹性盒子定义

弹性盒子是 CSS3 的一种新的布局模式

CSS3 弹性盒是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式

引入弹性盒布局模型的目的是提供一种更有效的方式来对一个容器中的子元素进行排列、对齐和分配空白空间。

二、CSS3 弹性盒内容

弹性盒子由弹性容器 (Flex container) 和弹性子元素 (Flex item) 组成弹性容器通过设置 display 属性的值为 flex 将其定义为弹性容器弹性容器内包含了一个或多个弹性子元素

它主要是在一个大的容器当中里面子元素的一个设置。一个大的盒子里面里面的子元素如何排列由我们的弹性盒子控制。

注意: 弹性容器外及弹性子元素内是正常渲染的。弹性盒子只定义了弹性子元素如何在弹性容器内布局

1. 不使用 display:flex;弹性盒子和使用 display:flex;弹性盒子的对比

CSS 弹性盒子(详细版,建议收藏)

css 

 

HTML


    
盒子 1
盒子 2
盒子 3

 这是使用 display:flex;的布局

CSS 弹性盒子(详细版,建议收藏)

2.flex-direction 属性指定单行元素在父容器中的排列方式。

flex-direction的值有: 

  1. row:横向从左到右排列(左对齐),默认的排列方式。
  2. row-reverse:反转横向排列(右对齐,从后往前排,最后一项排在最前面。
  3. column:纵向排列。
  4. column-reverse:反转纵向排列,从后往前排,最后一项排在最上面。

 HTML


    
1
2
3
4
5
1
2
3
4
5
1
2
3
4
5
1
2
3
4
5

css

运行示例图

CSS 弹性盒子(详细版,建议收藏)

 

2、flex-wrap 属性用来设置当弹性盒子的子元素(项目)超出父容器时是否换行

flex-wrap 的值有:

1.nowrap:默认值 项目不会换行,容器为单行,子项可能会溢出容器。

2.wrap:容器为多行,子项溢出的部分会被放置到新的行。

3.wrap_reverse: 项目在需要时换行,但会以相反的顺序排列

HTML


    
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10

 css

运行示例图

CSS 弹性盒子(详细版,建议收藏)

3.flex-flow:属性是 flex-direction 和 flex-wrap 两个属性的简写 

flex-flow:flex-direction flex-wrap;

 HTML


    
12345678910

css 

运行示例图 

CSS 弹性盒子(详细版,建议收藏)

4.justify-content:属性用于设置弹性盒子中元素在主轴方向上的对齐方式

justify-content 的值有:

 1.flex-start:默认值,靠左对齐 依次紧挨着平铺

 2.flex-end:靠右对齐 依次紧挨着平铺

 3.center: 居中 

 4. space-between: 两端对齐 每个项目之间的间隔是相等的

 5.space-around: 每个项目两侧的间隔相等

HTML 


        
12345
678910
12345
678910
12345

css 

运行示例图 

CSS 弹性盒子(详细版,建议收藏)

5.align-items:属性用来设置弹性盒子中元素在纵轴方向上的对齐方式

align-items 的值有:

1.stretch:默认值 将项目拉伸与容器相合适

2.center: 位于容器的中间,

3.flex-start: 位于容器的顶部,纵轴起始位置的边界紧靠住该行的侧轴起始边界

4.flex-end: 位于容器的底部,纵轴起始位置的边界紧靠住该行的侧轴结束边界

5.baseline: 项目与容器的基本线对齐,

HTML 

例:
1
2
3
4
5

css 

例:

效果运行示例图

CSS 弹性盒子(详细版,建议收藏)

6.css3 弹性盒子常用属性 

原文地址: CSS 弹性盒子(详细版,建议收藏)

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于2024-10-07发表,共计4094字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)