css 避免在悬停时展开Flex元素并向下拖动其他元素

5kgi1eie  于 2023-06-07  发布在  其他
关注(0)|答案(1)|浏览(130)

有没有可能使hover元素不向下推其他元素从而扩展整个flexbox,而是让它与其他元素重叠并将它们隐藏在其主体中?
我尝试了z-index,但没有成功。

.flex-container {
  display: flex;
  justify-content: space-evenly;
  flex: auto;
}

.flex-container>div {
  background-color: #f1f1f1;
  width: 100%;
  margin: 10px;
  line-height: 15px;
  font-size: 15px;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}

.child {
  display: none;
  position: relative;
}

.main:hover+.child {
  display: block;
  color: red;
  background-color: yellow;
  z-index: 1;
}
<div class="flex-container">
  <div class="wrapper">
    <p class="main">
      Lorem ipsum dolor sit amet, consectetur adipisicing elit.
    </p>
    <div class="child">
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem, possimus, a! Accusantium temporibus culpa neque ullam libero ipsam, nesciunt id quisquam omnis, possimus error praesentium eum earum dignissimos, quaerat numquam!
      </p>
    </div>
    <p class="main">
      Lorem ipsum dolor sit amet, consectetur adipisicing elit.
    </p>
    <div class="child">
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem, possimus, a! Accusantium temporibus culpa neque ullam libero ipsam, nesciunt id quisquam omnis, possimus error praesentium eum earum dignissimos, quaerat numquam!
      </p>
    </div>
    <p class="main">
      Lorem ipsum dolor sit amet, consectetur adipisicing elit.
    </p>
    <div class="child">
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem, possimus, a! Accusantium temporibus culpa neque ullam libero ipsam, nesciunt id quisquam omnis, possimus error praesentium eum earum dignissimos, quaerat numquam!
      </p>
    </div>
  </div>
  <div class="wrapper"></div>
</div>
eni9jsuy

eni9jsuy1#

在您的示例中,您必须将鼠标悬停在p元素上,子元素将展开或显示,但是当您从p元素释放光标时,子元素将隐藏,因此请尝试以下代码并更改一些代码结构以满足您的要求。

.flex-container {
        display: flex;
        justify-content: space-evenly;
        flex: auto;
    }

    .flex-container>div {
        background-color: #f1f1f1;
        width: 100%;
        margin: 10px;
        line-height: 15px;
        font-size: 15px;
        border-radius: 10px;
        overflow: hidden;
        position: relative;
    }

    .child {
        display: none;
        position: relative;
    }

    .main {
        padding: 10px;
    }

    .main p {
        margin: 0;
    }

    .main:hover>.child {
        display: block;
        color: red;
        background-color: yellow;
        z-index: 1;
        margin-top: 10px;
    }
<div class="flex-container">
        <div class="wrapper">
            <div class="main">
                <p class="main-test">
                    Lorem ipsum dolor sit amet, consectetur adipisicing elit.
                </p>
                <div class="child">
                    <p>
                        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem, possimus, a! Accusantium temporibus culpa neque ullam libero ipsam, nesciunt id quisquam omnis, possimus error praesentium eum earum dignissimos, quaerat numquam!
                    </p>
                </div>
            </div>
            <div class="main">
                <p class="main-test">
                    Lorem ipsum dolor sit amet, consectetur adipisicing elit.
                </p>
                <div class="child">
                    <p>
                        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem, possimus, a! Accusantium temporibus culpa neque ullam libero ipsam, nesciunt id quisquam omnis, possimus error praesentium eum earum dignissimos, quaerat numquam!
                    </p>
                </div>
            </div>
            <div class="main">
                <p class="main-test">
                    Lorem ipsum dolor sit amet, consectetur adipisicing elit.
                </p>
                <div class="child">
                    <p>
                        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem, possimus, a! Accusantium temporibus culpa neque ullam libero ipsam, nesciunt id quisquam omnis, possimus error praesentium eum earum dignissimos, quaerat numquam!
                    </p>
                </div>
            </div>
        </div>
        <div class="wrapper">
        </div>
    </div>

相关问题