css flex布局

flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。主要有一下几点优势,任何一个容器都可以指定为 Flex 布局.
第一,屏幕和浏览器窗口大小发生改变也可以灵活调整布局;
第二,可以指定伸缩项目沿着主轴或侧轴按比例分配额外空间(伸缩容器额外空间),从而调整伸缩项目的大小;
第三,可以指定伸缩项目沿着主轴或侧轴将伸缩容器额外空间,分配到伸缩项目之前、之后或之间;
第四,可以指定如何将垂直于元素布局轴的额外空间分布到该元素的周围;
第五,可以控制元素在页面上的布局方向;
第六,可以按照不同于文档对象模型(DOM)所指定排序方式对屏幕上的元素重新排序。也就是说可以在浏览器渲染中不按照文档流先后顺序重排伸缩项目顺序。
采用flex布局的元素被称为容器,其内部所有子元素称为项目。
1、容器属性
flex-direction:flex布局中元素的排列方式,默认值row.
row:从左到右水平排列 row-reverse:从由到左水平排列
column:从上到下垂直排列 column-reverse:从下到上垂直排列
flex-wrap:设置flex容器中当一行中的内容超过容器宽度时的排列方式,默认值nowrap.
nowrap:将超过的内容强行挤到同一行,当元素间有margin值时会压缩margin值,没有时会压缩每个元素的宽度。
wrap:将超过的元素放到下一行。
wrap-reverse:将超过的元素放在当前行,而没有超过的元素放在下一行。
flex-flow:flex-direction与flex-wrap组合写法,默认值row nowrap.
justify-content:用于设置容器内元素在水平方向上的对齐方式,默认值flex-start.
flex-start:左对齐 flex-end:右对齐 center:居中
space-between:元素紧贴容器左右两端,元素间的间距相同。
space-around:元素与容器左右两端距离为元素间距离的一半,元素间的距离相同。
space-evenly:元素间的间距相同,且两端元素和元素间的间距也是相同的。
align-items:设置容器内元素在垂直方向上的对齐方式,默认值stretch.
flex-start:以容器顶部来对齐 flex-end:以容器底部来对齐
center:以容器中间来对齐 baseline:按容器内元素的文字来对齐 stretch:当容器内元素未设置高度时默认沾满整个容器高度
align-content:设置了容器内多行元素的对齐方式,只有一行时该样式无效,默认值stretch.
flex-start:第一行紧贴顶部 flex-end:最后一行紧贴底部
center:中间一行居中,其他行紧贴中间行
space-between:不同行行间距相同,第一行和最后一行与容器顶部底部紧贴
space-arount:不同行行距相同,第一行和最后一行与容器顶部底部距离为行距一半 stretch:各行沾满容器
2、元素属性
order:用于决定元素排列顺序,数值越小,元素排列越靠前,默认值0.
flex-grow:定义元素的放大比例,默认值0(如果存在剩余空间也不放大)。如果所有项目的flex-grow属性都为1,则他们将等分剩余空间(如果有的话);如果一个项目的flex-grow属性值为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。
flex-shrink:定义元素的缩小比例,默认值1(如果空间不足将缩小)。如果一个元素的flex-shrink属性值为0,其他元素都为1,则空间不足时,前者不缩小。负值对该属性无效。
flex-basis:定义了在分配多余空间之前,项目占据的主轴空间,浏览器根据这个属性计算主轴是否有多余空间,默认值auto(项目本来大小)。他可以设定为跟width height属性一样的值(200px),即项目将占据固定空间。
flex:flex-grow flex-shrink flex-basis三者的简写,默认值0 1 auto,后两个属性可选。
align-self:允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items,默认值auto,标识继承父元素的align-items属性,如果没有父元素,则等同于stretch .与align-items属性值相比多了auto,其他一样。
3、示例


image.png
<style>
    .div_row {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: flex-start;
      align-items: flex-start;
      align-content: stretch;
      width: 100%;
      height: 200px;
    }

    .div_row div {
      width: 200px;
      background-color: red;
      margin-left: 10px;
    }

    .div_row2 {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: flex-start;
      align-items: flex-start;
      align-content: stretch;
      width: 100%;
      height: 200px;
    }

    .div_row2 div {
      width: 200px;
      background-color: rgb(136, 255, 0);
      margin-left: 10px;
    }

    .div1 {
      order: 1;
      flex-grow: 1;
      flex-shrink: 1;
      /* width: 300px; 设定flex-basis时 width无效 */
      flex-basis: 400px;
      align-self: center;
    }

    .div2 {
      order: 0;
      flex-grow: 0;
      flex-shrink: 1;
      /* width: 300px; 设定flex-basis时 width无效 */
      flex-basis: 400px;
      align-self: auto;
    }

    .div3 {
      order: 0;
      flex-grow: 0;
      flex-shrink: 1;
      /* width: 300px; 设定flex-basis时 width无效 */
      flex-basis: 400px;
      align-self: auto;
    }
</style>
<div class="div_row">
        <div>元素1</div>
        <div>元素2</div>
        <div>元素3</div>
        <div>元素4</div>
        <div>元素5</div>
        <div>元素6</div>
        <div>元素7</div>
      </div>
      <div class="div_row2">
        <div class="div1">元素1</div>
        <div class="div2">元素2</div>
        <div class="div3">元素3</div>
      </div>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,333评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,812评论 1 298
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,016评论 0 246
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,293评论 0 214
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,650评论 3 288
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,788评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,003评论 2 315
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,741评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,462评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,681评论 2 249
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,168评论 1 262
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,528评论 3 258
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,169评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,119评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,902评论 0 198
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,846评论 2 283
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,719评论 2 274

推荐阅读更多精彩内容

  • 第一部分: 前言 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性...
    奔云阅读 921评论 0 0
  • Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。 一、任何一个容...
    sarah_wqq阅读 583评论 0 1
  • 网页布局(layout)是 CSS 的一个重点应用。 布局的传统解决方案,基于盒状模型,依赖 display 属性...
    coderfl阅读 1,137评论 0 0
  • 转自博客园阮一峰《flex布局教程:语法篇》 网页布局(layout)是 CSS 的一个重点应用。 布局的传统解决...
    锴一的开发日记阅读 207评论 0 0
  • 最近在看小程序 一些css 因为之前没怎么了解过 看到这块特此记录--转自大神阮一峰http://www.ruan...
    我见青山应如是阅读 292评论 0 0