
本文旨在解决在 JavaScript 中,当 CSS 缩放动画正在进行时,如何获取元素缩放完成后的 `offsetX` 和 `offsetY` 值的问题。通过引入一个辅助的、无过渡的 `div` 元素,并将其放置在目标图像的下方,可以模拟缩放后的最终状态,从而准确获取鼠标在缩放完成后的位置信息。这种方法无需等待动画结束,即可立即获得目标值,提升用户体验。
在进行 CSS 缩放和过渡动画时,直接使用 event.offsetX 和 event.offsetY 获取的鼠标位置是动画过程中的瞬时值,而不是动画结束后的最终值。这在需要基于最终缩放比例进行计算或操作的场景下会带来问题。以下提供一种解决方案,通过添加一个辅助元素来解决这个问题。
该方案的核心思想是在目标图像下方创建一个不可见的 div 元素,该元素在缩放时没有过渡效果,立即达到最终的缩放比例。然后,将点击事件绑定到这个 div 元素上,通过它来获取鼠标位置信息。
1. HTML 结构调整:
立即学习“Java免费学习笔记(深入)”;
将目标图像 img 和辅助 div 放入一个容器 div#wrapper 中。辅助 div#target 覆盖整个图像区域,并负责接收点击事件。
<button onclick="onButton()">Zoom</button> <br> <div id="wrapper"> <div id="target" onclick="onImage(event)"></div> <img id="img" src="https://picsum.photos/id/237/200"> </div>
2. CSS 样式设置:
#wrapper {
display: inline-block;
position:relative;
font-size:0;
}
#target{
position:absolute;
width:100%;
height:100%;
}
#img {
transition: 5s ease;
z-index:2;
pointer-events:none;
}3. JavaScript 代码:
function onButton() {
const img = document.querySelector("#img");
img.style.scale = 5.0;
const target = document.querySelector("#target");
target.style.scale = 5.0;// make sure target's style matches img's style
}
function onImage(event) {
console.log(event.offsetX, event.offsetY);
}<!DOCTYPE html>
<html>
<head>
<style>
#wrapper {
display: inline-block;
position:relative;
font-size:0;
}
#target{
position:absolute;
width:100%;
height:100%;
}
#img {
transition: 5s ease;
z-index:2;
pointer-events:none;
}
</style>
</head>
<body>
<button onclick="onButton()">Zoom</button>
<br>
<div id="wrapper">
<div id="target" onclick="onImage(event)"></div>
<img id="img" src="https://picsum.photos/id/237/200">
</div>
<script>
function onButton() {
const img = document.querySelector("#img");
img.style.scale = 5.0;
const target = document.querySelector("#target");
target.style.scale = 5.0;// make sure target's style matches img's style
}
function onImage(event) {
console.log(event.offsetX, event.offsetY);
}
</script>
</body>
</html>通过引入辅助 div 元素,可以有效地解决 CSS 缩放动画期间 event.offsetX 和 event.offsetY 值不准确的问题。这种方法简单易懂,能够快速获取缩放完成后的鼠标位置信息,为后续的计算和操作提供准确的数据支持,提升用户体验。这种技巧在需要处理动画过程中鼠标事件的场景中非常有用。
以上就是JavaScript CSS 缩放动画期间获取最终 offset 值的替代方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号