CSS学习笔记(flex 伸缩布局 )(1)

本文介绍了Flexbox布局的基本原理,包括如何通过display属性实现伸缩容器,以及flex-direction和justify-content等关键属性的作用。还提到Flexbox在实际面试中的重要性,特别关注于前端技术点如HTML5、CSS、JavaScript等。
摘要由CSDN通过智能技术生成

display: flex | inline-flex;

Flexbox 由伸缩容器和伸缩项目组成。通过设置元素的 display 属性为 flex 或 inline-flex 可以得到一个伸缩容器。

设置为 flex 的容器被渲染成一个块元素,而设置为 inline-flex 的容器渲染为一个行内元素。属性值决定容器是如何显示的,它的所有子元素将变成 flex 文档流,被称为伸缩项目。

Tips:被定义为伸缩项目后,CSS 的 columns 属性在伸缩容器上没有效果,同时 float、clear 和 vertical-align 属性在伸缩项目上也没有效果

常规布局是基于块和文本流方向,而Flex 布局是基于 flex-flow,如下图所示:

在这里插入图片描述

主轴(main axis):伸缩容器的主轴,伸缩项目主要沿着这条轴进行排列布局。

主轴起点(main-start)和终点(main-end):伸缩项目放置在伸缩容器内从主轴起点向主轴终点方向。

主轴尺寸(main-size):伸缩项目在主轴方向的宽度或高度就是主轴的尺寸,伸缩项目主要的大小属性要么是宽度属性,要么是高度属性,是由哪一个对着主轴方向决定。

侧轴(cross axis):垂直于主轴称为侧轴。

侧轴起点(cross-start)和终点(cross-end):伸缩行的配置从容器的侧轴起点边开始,往侧轴终点结束。

侧轴尺寸(cross-size):伸缩项目的侧轴方向的宽度或高度就是项目的侧轴长度,伸缩项目的侧轴长度属性是width和height 属性,由哪一个对着侧轴方向决定。

方向:默认主轴从左向右,侧轴默认从上到下,主轴和侧轴并不是固定不变的,通过 flex-direction 可以互换。

Tips: 因为语法规范版本众多,浏览器支持不一致,致使Flexbox布局使用不多。

三、各个属性

1、定义宽高

  • flex子项目在主轴的缩放比例,不指定flex属性,则不参与伸缩分配。

min-width:定义最小宽度 max-width:定义最大宽度

2、定义主轴方向

  • 使用 flex-direction 属性来定义伸缩方向,主要用来创建主轴,从而定义伸缩项目在伸缩容器内的放置方向。

语法格式:

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

**row:默认值,水平排列

row-reverse:水平排列,与 row 方向相反

column:垂直排列,从上到下排列;

columns-reverse:垂直排列,从下到上排列**

3、定义水平对齐

  • justify-content 调整主轴对齐,该属性适用于伸缩容器。

语法格式:

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

最后

在面试前我花了三个月时间刷了很多大厂面试题,最近做了一个整理并分类,主要内容包括html,css,JavaScript,ES6,计算机网络,浏览器,工程化,模块化,Node.js,框架,数据结构,性能优化,项目等等。

包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。

  • HTML5新特性,语义化

  • 浏览器的标准模式和怪异模式

  • xhtml和html的区别

  • 使用data-的好处

  • meta标签

  • canvas

  • HTML废弃的标签

  • IE6 bug,和一些定位写法

  • css js放置位置和原因

  • 什么是渐进式渲染

  • html模板语言

  • meta viewport原理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值