html - 如何在水平 flexbox 中垂直对齐嵌套子项?

标签 html css flexbox vertical-alignment

正如您在下面的代码片段中看到的,foo-wrapper 下的点不遵循 bar-wrapper 下文本标签的垂直对齐方式。但根据 :nth-child(i) 规则,我预料到了这一点。

我如何制作点,它们是不同容器的子容器,随后是水平 flexbox(parent-wrapper)的子容器,遵循子容器的垂直对齐方式其他容器?

我是否必须完全放弃 flexbox 并使用网格布局之类的东西?

<!DOCTYPE html>

<head>
  <style>
    .parent-wrapper {
      align-items: stretch;
      display: flex;
      flex-flow: row nowrap;
      height: 256px;
      width: 100%;
    }
    
    .foo-wrapper {
      background-color: orange;
      margin: 1.5rem;
      width: 2px;
    }
    
    .dot {
      background-color: #ebf0ff;
      border-radius: 0.5rem;
      height: 1rem;
      width: 1rem;
    }
    
    .foo-wrapper div:nth-child(1) {
      margin-top: 1rem;
    }
    
    .foo-wrapper div:nth-child(2) {
      margin-top: 1rem;
    }
    
    .foo-wrapper div:nth-child(3) {
      margin-top: 1rem;
    }
    
    .bar-wrapper {
      border: 1px solid green;
      display: flex;
      flex-flow: column nowrap;
      margin: 1.5rem;
      flex-grow: 1;
    }
       
    .bar-wrapper div:nth-child(1) {
      margin-top: 1rem;
    }
    
    .bar-wrapper div:nth-child(2) {
      margin-top: 2rem;
    }
    
    .bar-wrapper div:nth-child(3) {
      margin-top: 4rem;
    }
  </style>
</head>

<body>
  <div class="parent-wrapper">
    <div class="foo-wrapper">
      <div class="dot"></div>
      <div class="dot"></div>
      <div class="dot"></div>
    </div>
    <div class="bar-wrapper">
      <div>Lorem</div>
      <div>ipsum</div>
      <div>dolores</div>
    </div>
  </div>
</body>

最佳答案

除了测量每个 bar-wrapper child 并动态分配高度 (js) 之外,我发现没有简单的方法可以做到这一点。目前最可行的解决方案似乎是重组您的布局。

案例 1:混合 bar-wrapper内容和foo-wrapper内容到一个单独的分区。

.wrapper{
   display: flex;
   align-items: flex-start;
}
...
<div class="wrapper">
   <div class="dot"/>
   <div class="content">
      <p>text</p>
   </div>
<div>

案例 2:如果您想要这种精确的设计,请将左侧的线分开(作为简单的 <div/> 或作为父容器的 border-left 并将点添加为伪元素,例如

.content::before{
   position: absolute;
   content:"";
   height: 14px;
   width: 14px;
   border-radius: 7px;
   background: #000000;
   margin-left: -18px;
}
.content{
  position: relative;
  padding-left: 18px;
}

填充和边距是可选的,具体取决于您的布局。

关于html - 如何在水平 flexbox 中垂直对齐嵌套子项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59127557/

相关文章:

html - 移动菜单按钮内的条形图不会出现在垂直中心

javascript - 每次输入字符时输入表单都会失去焦点

html - 导航栏中的水平对齐

html - 是否可以使用图像(html)高度和宽度标签覆盖图像的 css 高度和宽度?

HTML+CSS : 'a' width doesn't work

html - flex 元素不起作用。我怎样才能修复我的代码来解决这个问题?

javascript - 运行使用 json 的 ajax 函数后,浏览器保持加载(加载指示器保持旋转)

javascript - phonegap - 在智能手机上获取默认音乐文件夹的跨平台方式

html - 带有距离的子菜单,悬停时关闭

html - 是否可以收缩包裹内部文本的 flex 元素?