解决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>

此时我们再看效果:

相关推荐
周末也要写八哥4 小时前
html网页设计适合新手的学习路线总结
html
ZC跨境爬虫5 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝5 小时前
svg图片
前端·css·学习·html·css3
whuhewei10 小时前
JS获取CSS动画的旋转角度
前端·javascript·css
阿捞212 小时前
Inertia.js 持久布局实现原理
前端·javascript·html
你挚爱的强哥16 小时前
欺骗加载进度条,应用于无法监听接口数据传输进度的情况
前端·javascript·html
zhensherlock16 小时前
Protocol Launcher 系列:Mail Assistant 轻松发送 HTML 邮件
前端·javascript·typescript·node.js·html·github·js
冰暮流星17 小时前
javascript之dom访问css
开发语言·javascript·css
十一.36617 小时前
003-004 虚拟DOM的两种创建方式、虚拟DOM与真实DOM
前端·javascript·html
前端老石人17 小时前
无障碍访问
开发语言·前端·html