解决CSS中鼠标移入到某个元素其子元素被遮挡的问题

我们在开发中经常遇到一种场景,就是给元素加提示信息,就是鼠标移入到盒子上面时,会出现提示信息这一功能,如果我们给盒子加了hover,当鼠标移入到盒子上时,让他往上移动5px,即transform: translateY(-5px), 同时还让提示信息展示出来,此时受到transform的影响,提示信息会被父盒子遮挡住。代码如下:

html 复制代码
<template>
  <div class="container">
    <div
      class="item"
      v-for="item in 30"
      @mouseenter="showTooltip"
      @mouseleave="hideTooltip"
    >
      <div class="tooltip"></div>
      <span>{{ item }}</span>
    </div>
  </div>
</template>

<style>
.container {
  display: flex;
  flex-wrap: wrap;
  width: 1145px;
  margin: 0 auto;
  padding: 10px;
}
.item {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 120px;
  height: 120px;
  background-color: #eceff7;
  border-radius: 10px;
  margin: 10px;
  box-shadow: 0 3px 5px 2px rgba(0, 0, 0, 0.1);
  cursor: pointer;
  transition: all 0.5s ease;;
}

.item .tooltip {
  display: none;
  width: 100px;
  height: 30px;
  background-color: #000;
  border-radius: 6px;
  position: absolute;
  bottom: -50px;
  z-index: 10;
}
.item .tooltip::after {
  position: absolute;
  left: 0;
  top: -25px;
  width: 0;
  height: 0;
  left: 50%;
  transform: translateX(-50%);
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 15px solid transparent;
  border-bottom: 15px solid #000;
  content: "";
  z-index: 20px;
}
.item:hover {
  transform: translateY(-5px);
}
.item:hover .tooltip {
  display: block;
}
</style>

我们可以看到,我们给tooltip设置了z-index值为10,但是黑色提示信息依然被挡住了,原因时当hover时,执行了transform, 会改变元素的层级,

此时我们只需要给 .item:hover 加上一句 z-index: 1, 保证hover的时候,层级比item更低,就能解决这个问题。

html 复制代码
<template>
  <div class="container">
    <div
      class="item"
      v-for="item in 30"
      @mouseenter="showTooltip"
      @mouseleave="hideTooltip"
    >
      <div class="tooltip"></div>
      <span>{{ item }}</span>
    </div>
  </div>
</template>
<style>
.container {
  display: flex;
  flex-wrap: wrap;
  width: 1145px;
  margin: 0 auto;
  padding: 10px;
}
.item {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 120px;
  height: 120px;
  background-color: #eceff7;
  border-radius: 10px;
  margin: 10px;
  box-shadow: 0 3px 5px 2px rgba(0, 0, 0, 0.1);
  cursor: pointer;
  transition: all 0.5s ease;;
}

.item .tooltip {
  display: none;
  width: 100px;
  height: 30px;
  background-color: #000;
  border-radius: 6px;
  position: absolute;
  bottom: -50px;
  z-index: 10;
}
.item .tooltip::after {
  position: absolute;
  left: 0;
  top: -25px;
  width: 0;
  height: 0;
  left: 50%;
  transform: translateX(-50%);
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 15px solid transparent;
  border-bottom: 15px solid #000;
  content: "";
  z-index: 20px;
}
.item:hover {
  z-index: 1; /* 保证hover的时候z-index层级更低 */
  transform: translateY(-5px);
}
.item:hover .tooltip {
  display: block;
}
</style>

此时我们再看效果:

相关推荐
2301_8156453814 小时前
html.
前端·html
qq_3813385015 小时前
CSS @layer 级联层实战指南:从样式冲突到分层架构
前端·css
ZC跨境爬虫15 小时前
跟着 MDN 学 HTML day_33:(Attr 接口与属性节点的深入理解)
前端·javascript·ui·html·音视频·html5
用户0595401744616 小时前
AI Agent记忆丢失踩坑实录:这个问题让我排查了3天
前端·css
不瘦80斤不改名18 小时前
HTML基础(一)
开发语言·前端·html
前端若水18 小时前
原生嵌套(Nesting):以后还写 SCSS 吗?
前端·css·scss
ZC跨境爬虫18 小时前
跟着 MDN 学 HTML day_32:(AbstractRange 抽象接口与 DOM 范围操作)
前端·javascript·ui·html·音视频
羽沢3119 小时前
Canvas学习一
前端·css·学习·canvas
四岁爱上了她20 小时前
自定义标签切换动画
javascript·css·css3
普修罗双战士20 小时前
专业Markdown转HTML工具类:修复优化与Spring Boot适配
windows·spring boot·html