0

在下面的示例片段中,我尝试对元素的最后一个子.container元素施加与 相同border-radius的内容.container,以便当最后一个子元素在悬停时突出显示时,其背景会跟随父元素的形状。在我根据像素设置的特定情况下,这似乎工作得很好。border-radius

.container {
  display: block;
  width: 10em;
  border: 1px solid #999;
  border-radius: 0 0 20px 0;
  box-shadow: 0.1em 0.1em 0.4em black;
}

.entry:hover {
  background-color: #aaa;
}

.entry:last-child {
  border-radius: inherit;
}
<div class="container">
  <div class="entry">
  First
  </div>
  <div class="entry">
  second
  </div>
  <div class="entry">
  third
  </div>
</div>

但是,如果我使用ems,2em而不是s 20px,事情会像这样中断:

在此处输入图像描述

我猜这是因为父母的曲率比最后一个孩子的高度要高。事实上,如果我20px改为50px我得到这个:

在此处输入图像描述

因此,我认为20px我只是幸运,而border-radius试图让孩子跟随父母的形状而继承的整体方法是错误的。实际上,在 的最后一个示例中50px,必须将第二个条目裁剪掉,而这根本无法通过 获得border-radius

我该怎么做呢?

4

1 回答 1

3

尝试添加overflow: hidden到容器中

.container {
  display: block;
  width: 10em;
  border: 1px solid #999;
  border-radius: 0 0 2em 0;
  box-shadow: 0.1em 0.1em 0.4em black;
  overflow: hidden;
}

.entry:hover {
  background-color: #aaa;
}

.entry:last-child {
  border-radius: inherit;
}
<div class="container">
  <div class="entry">
  First
  </div>
  <div class="entry">
  second
  </div>
  <div class="entry">
  third
  </div>
</div>

于 2021-08-30T08:58:00.573 回答