gpt4 book ai didi

html - 悬停时的 CSS 比例,叠加层和边框之间的空间

转载 作者:行者123 更新时间:2023-11-28 05:48:42 25 4
gpt4 key购买 nike

当我悬停在一个 div 上时,左边似乎有一个小间隙,右边有黑边。这是 div 的左右部分;

enter image description here

这是重现问题的 fiddle 和代码; https://jsfiddle.net/hqk54p9k/

HTML:

<div class="form">
<div class="poster-list">
<div class="poster">
<div class="poster-overlay">
HELLO
</div>
<div class="poster-image">
</div>
</div>
</div>
</div>

CSS:

.form {
position:absolute;
top: 0;
left: 0;
width: 100%;
height: 500px;
background-color: black;
}

.poster {
position: relative;
display: inline-block;
width: 16.66667%;
padding-bottom: 25%;
border: 4px solid transparent;
vertical-align: top;

transition: all .2s ease-in-out;
overflow: hidden;

&:hover {
border: 4px solid #1599d6 !important;
transform: scale(1.1);
}

.poster-image {
background-color: red;
left: 0;
top: 0;
right: 0;
bottom: 0;
position: absolute;
}

.poster-overlay {
height: 50px;
background-color: white;
opacity: 1;
position: absolute;
bottom: 0;
left: 0;
width: 100%;
z-index: 1;
text-align: center;
}
}

.poster-list {
margin: 20px;
}

这个问题的原因是什么?

最佳答案

奇怪。这是一种视错觉。

我刚刚尝试更改了 .poster-image { background-color: red; } 颜色为 green 然后它就消失了。此外,blue 没有“空格”,只有 red

当设置 background-color: red 时(使用 Chrome/Ubuntu),我在左侧看不到任何“间隙”,只在右侧看到黑色间隙。

编辑

将 CSS 更改为此

.poster-image {
...
border: 1px solid transparent;
background-color: white;

&:hover {
outline: 4px solid #1599d6 !important;
...

如果 border: 1px 则有一个微小的白色边框,并且效果不会发生。

如果 border: 0px 和微小的白色边框不存在,效果就会发生。

当我使用浏览器缩放进行放大时,效果不会增大。它仍然是一条细线,宽度小于一个完整像素。我认为这是一个从浏览器到边缘的抗锯齿的渲染问题。

关于html - 悬停时的 CSS 比例,叠加层和边框之间的空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37462010/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com