>>分享Web前端开发技术,并对孙卫琴的《精通Vue.js:Web前端开发技术详解》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 21178 个阅读者 刷新本主题
 * 贴子主题:  CSS3 弹性盒子 回复文章 点赞(0)  收藏  
作者:sunshine    发表时间:2019-08-12 20:43:45     消息  查看  搜索  好友  邮件  复制  引用

  

CSS3 弹性盒子(Flex Box)

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

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

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

浏览器支持

     表格中的数字表示支持该属性的第一个浏览器的版本号。

     紧跟在数字后面的 -webkit- 或 -moz- 为指定浏览器的前缀。

              
属性
Basic support
(single-line flexbox)
29.0
21.0 -webkit-
11.0 22.0
18.0 -moz-
6.1 -webkit- 12.1 -webkit-
Multi-line flexbox 29.0
21.0 -webkit-
11.0 28.0 6.1 -webkit- 17.0
15.0 -webkit-
12.1
        

CSS3 弹性盒子内容

        弹性盒子由弹性容器(Flex container)和弹性子元素(Flex item)组成。

         弹性容器通过设置 display 属性的值为 flex 或 inline-flex将其定义为弹性容器。

         弹性容器内包含了一个或多个弹性子元素。

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

         弹性子元素通常在弹性盒子内一行显示。默认情况每个容器只有一行。

         以下元素展示了弹性子元素在一行内显示,从左到右:                    

范例

< ! DOCTYPE   html >
< html >
< head >
< style >  .flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

.flex-item   {
     background-color:   cornflowerblue  ;
     width:   100 px  ;
     height:   100 px  ;
     margin:   10 px  ;
}  </ style >
</ head >
< body >

< div   class = " flex-container " >
   < div   class = " flex-item " > flex item 1 </ div >
   < div   class = " flex-item " > flex item 2 </ div >
   < div   class = " flex-item " > flex item 3 </ div >  
</ div >

</ body >
</ html >

                当然我们可以修改排列方式。

     如果我们设置  direction 属性为  rtl (right-to-left),弹性子元素的排列方式也会改变,页面布局也跟着改变:            

范例

body   {
     direction:   rtl  ;
}

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

.flex-item   {
     background-color:   cornflowerblue  ;
     width:   100 px  ;
     height:   100 px  ;
     margin:   10 px  ;
}

flex-direction

      flex-direction 属性指定了弹性子元素在父容器中的位置。    

语法

       flex-direction: row | row-reverse | column | column-reverse

       flex-direction的值有:    
  • row:横向从左到右排列(左对齐),默认的排列方式。
  • row-reverse:反转横向排列(右对齐,从后往前排,最后一项排在最前面。
  • column:纵向排列。
  • column-reverse:反转纵向排列,从后往前排,最后一项排在最上面。
    以下范例演示了  row-reverse 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-direction:   row-reverse  ;
     flex-direction:   row-reverse  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                以下范例演示了  column 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-direction:   column  ;
     flex-direction:   column  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                以下范例演示了  column-reverse 的使用:                    

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-direction:   column-reverse  ;
     flex-direction:   column-reverse  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

justify-content 属性

     内容对齐(justify-content)属性应用在弹性容器上,把弹性项沿着弹性容器的主轴线(main axis)对齐。

     justify-content 语法如下:

         justify-content: flex-start | flex-end | center | space-between | space-around

     各个值解析:    
  • flex-start:

             弹性项目向行头紧挨着填充。这个是默认值。第一个弹性项的main-start外边距边线被放置在该行的main-start边线,而后续弹性项依次平齐摆放。
  • flex-end:

    弹性项目向行尾紧挨着填充。第一个弹性项的main-end外边距边线被放置在该行的main-end边线,而后续弹性项依次平齐摆放。
  • center:

    弹性项目居中紧挨着填充。(如果剩余的自由空间是负的,则弹性项目将在两个方向上同时溢出)。
  • space-between:

    弹性项目平均分布在该行上。如果剩余空间为负或者只有一个弹性项,则该值等同于flex-start。否则,第1个弹性项的外边距和行的main-start边线对齐,而最后1个弹性项的外边距和行的main-end边线对齐,然后剩余的弹性项分布在该行上,相邻项目的间隔相等。
  • space-around:

    弹性项目平均分布在该行上,两边留有一半的间隔空间。如果剩余空间为负或者只有一个弹性项,则该值等同于center。否则,弹性项目沿该行分布,且彼此间隔相等(比如是20px),同时首尾两边和弹性容器之间留有一半的间隔(1/2*20px=10px)。
     效果图展示:

         点击在新窗口中浏览原图
CTRL+鼠标滚轮放大或缩小

    以下范例演示了  flex-end 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-justify-content:   flex-end  ;
     justify-content:   flex-end  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                 以下范例演示了  center 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-justify-content:   center  ;
     justify-content:   center  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                 以下范例演示了  space-between 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-justify-content:   space-between  ;
     justify-content:   space-between  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                   以下范例演示了  space-around 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-justify-content:   space-around  ;
     justify-content:   space-around  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

align-items 属性

    align-items 设置或检索弹性盒子元素在侧轴(纵轴)方向上的对齐方式。    

语法

             align-items: flex-start | flex-end | center | baseline | stretch

    各个值解析:    
  • flex-start:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴起始边界。
  • flex-end:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴结束边界。
  • center:弹性盒子元素在该行的侧轴(纵轴)上居中放置。(如果该行的尺寸小于弹性盒子元素的尺寸,则会向两个方向溢出相同的长度)。
  • baseline:如弹性盒子元素的行内轴与侧轴为同一条,则该值与'flex-start'等效。其它情况下,该值将参与基线对齐。
  • stretch:如果指定侧轴大小的属性值为'auto',则其值会使项目的边距盒的尺寸尽可能接近所在行的尺寸,但同时会遵照'min/max-width/height'属性的限制。
     以下范例演示了  stretch(默认值) 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-align-items:   stretch  ;
     align-items:   stretch  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

               以下范例演示了  flex-start 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-align-items:   flex-start  ;
     align-items:   flex-start  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                 以下范例演示了  flex-end 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-align-items:   flex-end  ;
     align-items:   flex-end  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                  以下范例演示了  center 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-align-items:   center  ;
     align-items:   center  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

                以下范例演示了  baseline 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-align-items:   baseline  ;
     align-items:   baseline  ;
     width:   400 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

flex-wrap 属性

     flex-wrap 属性用于指定弹性盒子的子元素换行方式。    

语法

             flex-wrap: nowrap|wrap|wrap-reverse|initial|inherit;

    各个值解析:    
  • nowrap - 默认,

    弹性容器为单行。该情况下弹性子项可能会溢出容器。
  • wrap -

    弹性容器为多行。该情况下弹性子项溢出的部分会被放置到新行,子项内部会发生断行
  • wrap-reverse -反转 wrap 排列。
     以下范例演示了  nowrap 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-wrap:   nowrap  ;
     flex-wrap:   nowrap  ;
     width:   300 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

    以下范例演示了  wrap 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-wrap:   wrap  ;
     flex-wrap:   wrap  ;
     width:   300 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

      以下范例演示了  wrap-reverse 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-wrap:   wrap-reverse  ;
     flex-wrap:   wrap-reverse  ;
     width:   300 px  ;
     height:   250 px  ;
     background-color:   lightgrey  ;
}

align-content 属性

      align-content 属性用于修改flex-wrap 属性的行为。
     类似于  align-items, 但它不是设置弹性子元素的对齐,而是设置各个行的对齐。    

语法

    align-content: flex-start | flex-end | center | space-between | space-around | stretch

    各个值解析:    
  •   stretch - 默认。各行将会伸展以占用剩余的空间。
  •   flex-start - 各行向弹性盒容器的起始位置堆叠。
  •   flex-end - 各行向弹性盒容器的结束位置堆叠。
  •   center -各行向弹性盒容器的中间位置堆叠。
  •   space-between -各行在弹性盒容器中平均分布。
  •   space-around - 各行在弹性盒容器中平均分布,两端保留子元素与子元素之间间距大小的一半。
     以下范例演示了  center 的使用:            

范例

.flex-container   {
     display:  - webkit-flex  ;
     display:   flex  ;
    - webkit-flex-wrap:   wrap  ;
     flex-wrap:   wrap  ;
    - webkit-align-content:   center  ;
     align-content:   center  ;
     width:   300 px  ;
     height:   300 px  ;
     background-color:   lightgrey  ;
}

弹性子元素属性

排序

语法

             order:

              各个值解析:    
  • <integer>:用整数值来定义排列顺序,数值小的排在前面。可以为负值。
      order 属性设置弹性容器内弹性子元素的属性:            

范例

.flex-item   {
     background-color:   cornflowerblue  ;
     width:   100 px  ;
     height:   100 px  ;
     margin:   10 px  ;
}

.first   {
    - webkit-order:  - 1  ;
     order:  - 1  ;
}

对齐

     设置"margin"值为"auto"值,自动获取弹性容器中剩余的空间。所以设置垂直方向margin值为"auto",可以使弹性子元素在弹性容器的两上轴方向都完全居中。

     以下范例在第一个弹性子元素上设置了  margin-right: auto; 。 它将剩余的空间放置在元素的右侧:            

范例

.flex-item   {
     background-color:   cornflowerblue  ;
     width:   75 px  ;
     height:   75 px  ;
     margin:   10 px  ;
}

.flex-item :first-child   {
     margin-right:   auto  ;
}

完美的居中

     以下范例将完美解决我们平时碰到的居中问题。

    使用弹性盒子,居中变的很简单,只想要设置   margin: auto; 可以使得弹性子元素在两上轴方向上完全居中:            

范例

.flex-item   {
     background-color:   cornflowerblue  ;
     width:   75 px  ;
     height:   75 px  ;
     margin:   auto  ;
}

align-self

      align-self 属性用于设置弹性元素自身在侧轴(纵轴)方向上的对齐方式。    

语法

             align-self: auto | flex-start | flex-end | center | baseline | stretch

      各个值解析:    
  • auto:如果'align-self'的值为'auto',则其计算值为元素的父元素的'align-items'值,如果其没有父元素,则计算值为'stretch'。
  • flex-start:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴起始边界。
  • flex-end:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴结束边界。
  • center:弹性盒子元素在该行的侧轴(纵轴)上居中放置。(如果该行的尺寸小于弹性盒子元素的尺寸,则会向两个方向溢出相同的长度)。
  • baseline:如弹性盒子元素的行内轴与侧轴为同一条,则该值与'flex-start'等效。其它情况下,该值将参与基线对齐。
  • stretch:如果指定侧轴大小的属性值为'auto',则其值会使项目的边距盒的尺寸尽可能接近所在行的尺寸,但同时会遵照'min/max-width/height'属性的限制。
     以下范例演示了弹性子元素上 align-self 不同值的应用效果:            

范例

.flex-item   {
     background-color:   cornflowerblue  ;
     width:   60 px  ;
     min-height:   100 px  ;
     margin:   10 px  ;
}

.item1   {
    - webkit-align-self:   flex-start  ;
     align-self:   flex-start  ;
}
.item2   {
    - webkit-align-self:   flex-end  ;
     align-self:   flex-end  ;
}

.item3   {
    - webkit-align-self:   center  ;
     align-self:   center  ;
}

.item4   {
    - webkit-align-self:   baseline  ;
     align-self:   baseline  ;
}

.item5   {
    - webkit-align-self:   stretch  ;
     align-self:   stretch  ;
}

flex

      flex 属性用于指定弹性子元素如何分配空间。    

语法

             flex: auto | initial | none | inherit |  [ flex-grow ] || [ flex-shrink ] || [ flex-basis ]

    各个值解析:    
  • auto: 计算值为 1 1 auto
  • initial: 计算值为 0 1 auto
  • none:计算值为 0 0 auto
  • inherit:从父元素继承
  • [ flex-grow ]:定义弹性盒子元素的扩展比率。
  • [ flex-shrink ]:定义弹性盒子元素的收缩比率。
  • [ flex-basis ]:定义弹性盒子元素的默认基准值。
     以下范例中,第一个弹性子元素占用了 2/4 的空间,其他两个各占 1/4 的空间:            

范例

.flex-item   {
     background-color:   cornflowerblue  ;
     margin:   10 px  ;
}

.item1   {
    - webkit-flex:   2  ;
     flex:   2  ;
}

.item2   {
    - webkit-flex:   1  ;
     flex:   1  ;
}

.item3   {
    - webkit-flex:   1  ;
     flex:   1  ;
}

CSS3 弹性盒子属性

     下表列出了在弹性盒子中常用到的属性:

      
属性 描述
display 指定 HTML  元素盒子类型。
flex-direction 指定了弹性容器中子元素的排列方式
justify-content 设置弹性盒子元素在主轴(横轴)方向上的对齐方式。
align-items 设置弹性盒子元素在侧轴(纵轴)方向上的对齐方式。
flex-wrap 设置弹性盒子的子元素超出父容器时是否换行。
align-content 修改 flex-wrap 属性的行为,类似

align-items, 但不是设置子元素对齐,而是设置行对齐
flex-flow flex-direction 和 flex-wrap 的简写
order 设置弹性盒子的子元素排列顺序。
align-self 在弹性子元素上使用。覆盖容器的 align-items 属性。
flex 设置弹性盒子的子元素如何分配空间。






程序猿的技术大观园:www.javathinker.net



[这个贴子最后由 flybird 在 2020-02-26 12:07:11 重新编辑]
  Java面向对象编程-->继承
  JavaWeb开发-->Web运作原理(Ⅰ)
  JSP与Hibernate开发-->域对象在持久化层的四种状态
  Java网络编程-->用Swing组件展示HTML文档
  精通Spring-->CSS过渡和动画
  Vue3开发-->绑定表单
  Webpack 插件开发指南
  axios 发 post 请求,后端接收不到参数的解决方案
  axios.all()解决并发请求
  Axios拦截器的用法
  JavaScript ES2015模块化操作
  CSS3的@keyframes用法详解
  vue中axios异步调用接口的坑
  BootStrap, React, Vue的比较
  css 实现不定数量的tab切换和页面切换
  Vue. 入门篇
  史上最全的web前端面试题汇总及答案
  一个AJAX入门范例
  JavaScript的Window 对象
  jQuery UI 范例 - 选择条目(Selectable)
  JavaScript 正则表达式
  更多...
 IPIP: 已设置保密
楼主      
1页 3条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。