display:flex 意思是弹性布局

本文介绍使用CSS的display:flex属性进行弹性布局的方法,包括解决传统布局的局限性,实现元素的灵活排列与居中,适用于不同屏幕尺寸。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载: http://www.cnblogs.com/manman04/p/5704660.html

display:flex 意思是弹性布局

 

首先flex的出现是为了解决哪些问题呢?

一、页面行排列布局

像此图左右两个div一排显示

可以用浮动的布局方式

html部分

css部分

这种布局有两个缺点

1.需要一个空div来清除浮动,当然也可以选用其他清除浮动的方法,但此处需要清除浮动才能不影响下面的布局。

2.当.left,.right 的宽度是固定的,浏览器宽度变的过窄时,.right会被挤到下面

用display:flex布局,可以解决这两个缺点

刚吃的html部分不变,css部分

父级元素定义display:flex,子元素宽度用flex来定义,flex:1 是均分父级元素。占的比例相同

1:2分时

同样分为3份时

flex是所占的比例,这样的布局就方便很多。

 

 二、div上下左右居中

我之前写过div上下左右居中的几种方法

其中有一个写了margin:auto auto;这个方法的使用前提就是先把父元素设为display:flex

html部分

css部分 

在未知div宽高时,用这种方法比较方便

这是我在使用flex布局时用到的两个比较常见又好用的例子



### 解决 `display: flex` 子元素不自动拉伸的问题 当遇到 `display: flex` 布局中的子元素未能按照预期进行拉伸的情况时,通常是因为某些 CSS 属性设置不当所致。为了确保子元素能够正常拉伸,可以考虑以下几个方面: #### 1. 设置父容器属性 确保父容器已经正确设置了 `display: flex` 或者 `inline-flex`,这会使得其内部的直接子元素成为弹性项并遵循相应的布局规则[^1]。 ```css .parent { display: flex; } ``` #### 2. 调整子元素的生长因子 (`flex-grow`) 为了让某个特定的子元素占据剩余的空间,应该给该子元素应用 `flex-grow` 属性,并将其值设为大于零的数值。这样即使其他兄弟节点存在固定尺寸,此元素也会尽可能扩展自己来填充可用空间[^3]。 ```css .child-that-needs-to-expand { flex-grow: 1; } ``` #### 3. 控制收缩行为 (`flex-shrink`) 有时尽管指定了增长比例,但由于页面宽度有限或其他原因导致无法完全展开,则可以通过调整 `flex-shrink` 来控制是否允许这些项目缩小以适应更小的空间。默认情况下它的值是 `1` 表示可缩减;而将其置为 `0` 则意味着不允许任何程度上的压缩[^2]。 ```css .prevent-from-shrinking { flex-shrink: 0; } ``` 通过上述方法之一或组合使用,大多数关于 Flexbox 中子组件未按期望方式拉伸的问题都可以得到妥善处理。当然,在实际开发过程中还需要根据具体场景灵活运用这些技巧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值