如何用CSS3和JavaScript实现点击图片后周围图片散开并放大的效果?

css3和JavaScript实现图片点击散开放大效果

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

如何用CSS3和JavaScript实现点击图片后周围图片散开并放大的效果?

核心思想是利用css3transform属性控制图片位置和大小,JavaScript计算每个图片的位移和缩放比例,并应用到CSS样式中。

首先,为每个图片添加点击事件监听器,触发JavaScript函数(例如spread函数)。html代码示例:

@@##@@</img> @@##@@</img> @@##@@</img>

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实现点击图片后周围图片散开并放大的效果?如何用CSS3和JavaScript实现点击图片后周围图片散开并放大的效果?如何用CSS3和JavaScript实现点击图片后周围图片散开并放大的效果?

© 版权声明
THE END
喜欢就支持一下吧
点赞15 分享