CSS3和JavaScript实现图片点击散开放大效果
本文介绍如何使用css3和javascript实现点击图片后,周围图片以点击图片为中心散开并放大的交互效果。

核心思想是利用CSS3的transform属性控制图片位置和大小,JavaScript计算每个图片的位移和缩放比例,并应用到CSS样式中。
首先,为每个图片添加点击事件监听器,触发JavaScript函数(例如spread函数)。HTML代码示例:
@@##@@@@##@@@@##@@
spread函数获取所有图片元素,根据点击图片的索引计算其他图片的位移量。JavaScript代码示例:
function spread(img) { const images = document.querySelectorAll('img'); const index = Array.from(images).indexOf(img); const centerX = img.offsetLeft + img.offsetWidth / 2; const centerY = img.offsetTop + img.offsetHeight / 2; images.forEach((image, i) => { const dx = image.offsetLeft + image.offsetWidth / 2 - centerX; const dy = image.offsetTop + image.offsetHeight / 2 - centerY; const distance = Math.sqrt(dx * dx + dy * dy); const scale = i === index ? 2 : 1; // 点击图片放大两倍 const moveX = dx * (distance / 100); // 100为散开距离,可调整 const moveY = dy * (distance / 100); image.style.transform = `translate(${moveX}px, ${moveY}px) scale(${scale})`; });}
代码中,Math.sqrt计算距离,100控制散开半径,可根据需求调整。scale变量控制缩放比例,点击图片缩放比例为2,其他图片保持为1。
立即学习“Java免费学习笔记(深入)”;
最后,CSS设置图片初始样式,例如绝对定位和过渡效果:
img { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) scale(1); transition: transform 0.5s ease-in-out;}
transition属性提供平滑过渡效果。图片初始位置和散开半径需根据实际情况调整。 此代码已优化,使用querySelectorAll和Array.from提高效率,并更准确地计算中心点和位移。 记得替换image1.jpg,image2.jpg,image3.jpg为实际图片路径。



以上就是如何用CSS3和JavaScript实现点击图片后周围图片散开并放大的效果?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1564076.html
微信扫一扫
支付宝扫一扫