忽略 CSS 中悬停的边距

Zey*_*ch' 5 css hover

当我将鼠标悬停在正方形上时,我制作了一个小弹出窗口,但即使有现有边距,我也想转到此弹出窗口。

这是我的 HTML 和 CSS 代码的片段:

.vertical {
    height: 70px;
    width: 70px;
    border-radius: 5px;
    margin-bottom: 10px;
    margin-right: 10px;
    border: solid lightgrey;
    position: relative;
}

.frame {
    height: 100%;
}

.st {
    height: 250px;
}

.info {
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 120%;
    margin-left: -5px;
    border-radius: 5px;
    border: solid black 1px;
    color: white;
}

.vertical:hover .info {
    visibility: visible;
}

.arrow {
    position: absolute;
    right: 100%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent rgba(2, 0, 0, 0.75) transparent transparent;
    top: 25px;
}
Run Code Online (Sandbox Code Playgroud)
<div class="vertical">
   <div class="frame"></div>
   <div class="info">
      <div class="header">
         <div class="name">Hover</div>
      </div>
      <div class="st"></div>
      <div class="arrow"></div>
   </div>
</div>
Run Code Online (Sandbox Code Playgroud)

这是一个示例(如果您不按照箭头操作,弹出窗口将关闭):

https://jsfiddle.net/bpez64fr/

我想忽略边距并允许用户转到弹出窗口并使其像没有边距一样工作

nvi*_*oli 2

我的策略是将要显示的元素悬停在此处,left:100%以便光标没有间隙“落入”。然后,您可以使用padding此元素在主元素和悬停元素之间创建视觉空白,并将元素的内容放入.info-inner我的示例中的内部元素中。请注意,.info-inner必须是position:relative为了定位才能.arrow工作。

让我知道这是否适合您。

.vertical {
    height: 70px;
    width: 70px;
    border-radius: 5px;
    margin-bottom: 10px;
    margin-right: 10px;
    border: solid lightgrey;
    position: relative;
}

.frame {
    height: 100%;
}

.st {
    height: 250px;
}

.info {
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 100%;
    padding-left: 10px;
}

.info-inner {
    border-radius: 5px;
    border: solid black 1px;
    color: white;
    position: relative;
}

.vertical:hover .info {
    visibility: visible;
}

.arrow {
    position: absolute;
    right: 100%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent rgba(2, 0, 0, 0.75) transparent transparent;
    top: 25px;
}
Run Code Online (Sandbox Code Playgroud)
<div class="vertical">
   <div class="frame"></div>
   <div class="info">
      <div class="info-inner">
        <div class="header">
           <div class="name">Hover</div>
        </div>
        <div class="st"></div>
        <div class="arrow"></div>
      </div>
   </div>
</div>
Run Code Online (Sandbox Code Playgroud)