flex居中布局引起滚动溢出问题

场景

有一个flex布局的容器,item每个都有自己的固定宽度,如果item数量超过一定数值,则这个容器需要出现滚动条,代码如下:

html 复制代码
<div class="wrapper">
    <div>111</div>
    <div>222</div>
    <div>333</div>
    <div>444</div>
    <div>555</div>
</div>
css 复制代码
.wrapper{
  width: 800px;
  background-color: blue;
  display: flex;/*父div设置该属性*/
  overflow-x: scroll;
  justify-content: space-around;
  align-items: center;
}  
.wrapper::-webkit-scrollbar {
  display: none;  
}
.wrapper>div{
  width: 100px;
  height: 50px;
  border: 1px solid black;
  flex-shrink: 0;
}

效果如下:

目前是没问题的,但是当容器宽度变小后,我们期望出现滚动条,结果如下:

js 复制代码
.wrapper{
  width: 200px;  /*修改此处*/
  background-color: blue;
  display: flex;
  overflow-x: scroll;
  justify-content: space-around;
  align-items: center;
}  

chrome下没问题:

在safari上有问题,左侧无法看全,相当于溢出了

问题解决

方法有多种,我看到网上也挺多,我这里主要是多套一层的方式

方式一

多套一层,最外层设置flex布局

html 复制代码
<div class="next-main">
    <div class="next-main-div">
      <div>111</div>
      <div>222</div>
      <div>333</div>
      <div>444</div>
      <div>555</div>
    </div>
</div>
css 复制代码
.next-main {
  width: 200px;
  background-color: salmon;
  display: flex;/*父div设置该属性*/
  overflow-x: scroll;
  justify-content: space-around;
} 
.next-main .next-main-div {
  width: 100%;
  display: flex;
}  
.next-main-div > div {
  width: 100px;
  height: 50px;
  border: 1px solid black;
  flex-shrink: 0;
} 

通过外层多套一个容器,限定好width,当item数量不够时,自然居中,数量多余当前外容器宽度时候,则自动进行滚动,效果如下:

方法二

多套一层容器+inline-flex

inline-flex和flex区别在于inline-flex的外容器会根据内部item进行自动调整

html 复制代码
<div class="next-next-main">
    <div class="next-main-div">
      <div>111</div>
      <div>222</div>
      <div>333</div>
      <div>444</div>
      <div>555</div>
    </div>
</div>
css 复制代码
.next-next-main {
  width: 200px;
  background-color: darkgreen;
  overflow-x: scroll;
} 
.next-next-main .next-main-div {
  display: inline-flex;
  justify-content: space-around;
  align-items: center;
}
.next-main-div > div {
  width: 100px;
  height: 50px;
  border: 1px solid black;
  flex-shrink: 0;
} 

两种方案区别在于flex布局在那一层容器,最终结果都是一样的,第二种方案效果如下

以上就是两种嵌套父级方案了,至于其他方式,大家可以自行去查一下,比如margin: auto

相关推荐
码事漫谈17 分钟前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫22 分钟前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝23 分钟前
svg图片
前端·css·学习·html·css3
王夏奇40 分钟前
python中的__all__ 具体用法
java·前端·python
大家的林语冰1 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong232 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
田八2 小时前
聊聊AI的发展史,AI的爆发并不是偶然
前端·人工智能·程序员
zhanghongbin012 小时前
AI 采集器:Claude Code、OpenAI、LiteLLM 监控
java·前端·人工智能
IT_陈寒2 小时前
Python的列表推导式里藏了个坑,差点让我加班到凌晨
前端·人工智能·后端
吴声子夜歌2 小时前
ES6——正则的扩展详解
前端·mysql·es6