目录
CSS 转换未启动或未调用回调
问题摘要
解决方案说明
示例
首页 web前端 js教程 为什么我的 CSS 转换没有启动或触发回调函数,如何使用 setTimeout 修复它?

为什么我的 CSS 转换没有启动或触发回调函数,如何使用 setTimeout 修复它?

Oct 31, 2024 pm 09:00 PM

Why does my CSS transition not start or trigger the callback function, and how can I fix it using a setTimeout?

CSS 转换未启动或未调用回调

问题摘要

使用 CSS 转换更新 HTML 元素的位置。但是,尽管添加了转换transitionend事件侦听器,但转换无法触发或未调用回调函数。这个问题可以通过用 setTimeout(1ms) 包装更改来解决。

解决方案说明

此行为背后的原因在于浏览器的渲染过程。在浏览器应用 CSS 过渡之前,必须首先将内联样式应用到元素。如果该元素尚未在 DOM 中,则其计算样式显示设置为“”。

设置新样式时,浏览器尚未应用内联样式。因此,元素的计算样式仍为“”,其 left 和 top 值仍为 0px。

因此,当在下一帧绘制之前应用过渡属性时,left 和 top 值已经是所需的值,导致没有要执行的转换,也没有触发transitionend事件。

要解决此问题,可以使用 Element.offsetHeight getter 或其他需要最新样式的 DOM 方法强制回流。这会强制浏览器在应用过渡之前更新样式,确保顺利实现。

示例

以下代码演示了该问题及其解决方法:

<code class="html"><div id="spanky"
  style="position: absolute;
    left: 10px;
    top: 10px;
    background-color: blue;
    width: 20px;
    height: 20px;
    transition: left 1000ms linear 0s, top 1000ms linear 0s;">
</div></code>
登录后复制
<code class="js">document.body.innerHTML += tablehtml;

var animdiv = document.getElementById('spanky');
animdiv.addEventListener("transitionend", function(event) {
  animdiv.style.backgroundColor = 'red';
}, false);

// force a reflow
animdiv.offsetTop;

animdiv.style.backgroundColor = 'green';
Object.assign(animdiv.style, {
  left: "100px",
  top: "100px"
});</code>
登录后复制

在此示例中,animdiv 元素的 offsetTop getter 用于在其位置更新之前强制回流。这确保了 CSS 转换正确触发并调用回调函数。

以上是为什么我的 CSS 转换没有启动或触发回调函数,如何使用 setTimeout 修复它?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

在JavaScript中替换字符串字符 在JavaScript中替换字符串字符 Mar 11, 2025 am 12:07 AM

在JavaScript中替换字符串字符

jQuery检查日期是否有效 jQuery检查日期是否有效 Mar 01, 2025 am 08:51 AM

jQuery检查日期是否有效

jQuery获取元素填充/保证金 jQuery获取元素填充/保证金 Mar 01, 2025 am 08:53 AM

jQuery获取元素填充/保证金

10个jQuery手风琴选项卡 10个jQuery手风琴选项卡 Mar 01, 2025 am 01:34 AM

10个jQuery手风琴选项卡

10值得检查jQuery插件 10值得检查jQuery插件 Mar 01, 2025 am 01:29 AM

10值得检查jQuery插件

HTTP与节点和HTTP-Console调试 HTTP与节点和HTTP-Console调试 Mar 01, 2025 am 01:37 AM

HTTP与节点和HTTP-Console调试

自定义Google搜索API设置教程 自定义Google搜索API设置教程 Mar 04, 2025 am 01:06 AM

自定义Google搜索API设置教程

jQuery添加卷轴到Div jQuery添加卷轴到Div Mar 01, 2025 am 01:30 AM

jQuery添加卷轴到Div

See all articles