flex布局实用小集

全局概括

flex 容器中默认存在两条轴,水平主轴 main axis 和垂直的交叉轴 cross axis ,这是默认的设置,可以通过修改使垂直方向变为主轴,水平方向变为交叉轴

1、设置垂直居中

align-items:定义了项目在交叉轴上的对齐方式
justify-content:定义了项目在主轴的对齐方式

<style>
  # 垂直居中,设置父级为
  .flex-vertical-center{
      display: flex;
      align-items: center;
      justify-content: center;
  }
</style>
...
<div class="flex-vertical-center">
  <h2>这是一个垂直居中的布局</h2>
</div>

2、按比例均分自适应

flex-basis:定义了在分配多余空间之前,项目占据的主轴空间,浏览器根据这个属性,计算主轴是否有多余空间
flex-grow:定义项目的放大比例

  <style>
    .container{
      display: flex;
    }
    h1{
      flex-grow: 1;
    }
    h1:nth-child(1){
      background: red;
      flex-basis: 10%;      
    }
    h1:nth-child(2){
      background: palegoldenrod;
      flex-basis: 20%;      
      
    }
    h1:nth-child(3){
      background: paleturquoise;
      flex-basis: 30%;      
    }
  </style>
...

  <div class="container">
    <h1>1</h1>
    <h1>2</h1>
    <h1>3</h1>
  </div>

三个子元素会按照flex-basis设置的比例1:2:3来布局,但并不会占满父级,此时加上flex-grow: 1;他们会使用原来的比例占满父级,如果只使用flex-grow属性达到比例分割的效果:

  <style>
    .container{
      display: flex;
    }
    h1:nth-child(1){
      background: red;
      /* flex-basis: 10%;      */
      flex-grow: 1;
    }
    h1:nth-child(2){
      background: palegoldenrod;
      /* flex-basis: 20%;       */
      flex-grow: 2;
    }
    h1:nth-child(3){
      background: paleturquoise;
      /* flex-basis: 30%;      */
      flex-grow: 3;
    }
  </style>
...

  <div class="container">
    <h1>1</h1>
    <h1>2</h1>
    <h1>3</h1>
  </div>

如果混搭使用,已经使用flex-basis分好了比例1:2:3此时设置第一个h1flex-grow: 2;也就是放大了2倍,那么最终显示的比例就是2:2:3

其它相关属性:

当所有项目以 flex-basis 的值排列完后发现空间不够了,且 flex-wrap:nowrap 时,此时 flex-grow 则不起作用了,这时候就需要接下来的这个属性
flex-shrink:定义了项目的缩小比例
默认值: 1,即如果空间不足,该项目将缩小,负值对该属性无效
例如有6个div:每个项目都设置了宽度为 50px,但是由于自身容器宽度只有 200px,这时候每个项目会被同比例进行缩小,因为默认值为 1

上边提到的 flex-wrap决定容器内项目是否可换行
默认值 nowrap 不换行,即当主轴尺寸固定时,当空间不足时,项目尺寸会随之调整而并不会挤到下一行

缩写

看到这里,说一下缩写格式
flexflex-growflex-shrinkflex-basis 的简写
默认值:0 1 auto, 即不放大,可缩小,大小与 width、height

更新中....

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,290评论 6 491
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,107评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,872评论 0 347
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,415评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,453评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,784评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,927评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,691评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,137评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,472评论 2 326
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,622评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,289评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,887评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,741评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,977评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,316评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,490评论 2 348