html - 在 CSS 过渡结束时跳转

标签 html css css-transitions

当我将鼠标悬停在 div 上时,.note 跨度淡入。淡入后,字体粗细似乎突然增加(变得更粗)。我意识到在 fiddle没有图像,但不需要查看我的问题。

HTML:

<!DOCTYPE html>
<html>
<head>
    <link rel="stylesheet" type="text/css" href="style.css">
    <script src="script.js"></script>
    <title>Cool Effect</title>
</head>
<body>

    <div class="imageHolder">
        <img src="picture1.jpeg">
        <span class="note">Hello!</span>
    </div>

</body>
</html>

CSS:

.imageHolder {
    position: relative;
    top:300px;
    left: 300px;
    width: 300px;
    height: 250px;
    text-align: center;
    overflow: hidden;
    background-color: black;
}

.note {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    border: 2px solid white;
    padding: 8px;
    color: white;
    font-size: 24px;
    opacity: 0;
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
}

img {
    width: 300;
    opacity: 1;
    height: 250px;
}

.imageHolder:hover .note {
    opacity: 1;
}

谢谢。

最佳答案

使用 3d 变换(即使用硬件加速)可以解决许多此类渲染问题。

.note {
    ...
    -webkit-transform: translate3d(-50%, -50%, 0);
    transform: translate3d(-50%, -50%, 0);
    ...
}

Thiswell documented

DEMO


或者,这似乎也适用于您的示例,并且可能有更好的浏览器支持...

.note {
    ...
    -webkit-backface-visibility: hidden;
    ...
}

DEMO

关于html - 在 CSS 过渡结束时跳转,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31573142/

相关文章:

javascript - 如何在两个按钮之间切换

html - 如何对齐两个 flexbox 元素?

internet-explorer - 为什么这个rotate3d() CSS转换在Internet Explorer 10中不能按预期工作?

html - 选择图像时显示/隐藏按钮

javascript - 当用户向下滚动页面时增加元素不透明度

javascript - 在提交时在新选项卡中打开表单点击

淡入时 CSS 过渡延迟,淡出时无延迟

javascript - jquery ui可排序父元素和子元素

javascript - 在我的 HTML 代码中看不到 div 内的元素?

google-chrome - 为什么某些 CSS 属性的转换缓慢且不流畅