一个 CSS 布局和样式的问题,如何在水平居中和限制最大宽度中,进行平衡

在最近工作中,遇到一个这样的问题:

1. 背景

  • 水平三栏或者两栏的布局,其中一栏内的内容是变动的;
  • 当内容过少时,整体需要居中展示;
  • 当内容过多时,需要根据最大的宽度进行省略;

2. 实现的思路

整体的容器要添加属性:

.container {
    display: flex;
    justify-content: center;
}

2.1 使用 flex:1 来实现

之前的代码里,把变动的那一栏设置为 flex: 1 或者 flex: auto ,但这样存在的问题是,这块会把容器剩余的所有空间都占满,而不会根据内容自动调整;

2.2 设置 flex: none 来实现

这个存在的问题是,当内容过多时,不会盖住过多的内容

2.3 不设置属性

中间内容不固定的,则不设置任何 flex 属性,如果已经设置了不够,记得重新覆盖掉:

.clamp {
    flex: initial;
}

注意,这里使用的是 initial ,而不是 none。

同时还要注意,其他栏的宽度不要被挤压。我们左侧这一栏本来是放着一个图片,有设置宽度,但还是因为中间这一栏的内容过多,导致图片被压缩变形。所以,图片这里添加了一个 min-width 的属性。

标签:
CSS,水平居中,限定最大宽度

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“CSS 水平居中并限定最大的宽度实现”

暂无“CSS 水平居中并限定最大的宽度实现”评论...

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。