鼠标移动效果html5,js实现鼠标左右移动,图片也跟着移动效果

编程入门 行业动态 更新时间:2024-10-18 08:19:23

<a href=https://www.elefans.com/category/jswz/34/1769042.html style=鼠标移动效果html5,js实现鼠标左右移动,图片也跟着移动效果"/>

鼠标移动效果html5,js实现鼠标左右移动,图片也跟着移动效果

效果:鼠标往左移,图片对应右移,鼠标往右移,图片就左移动。图片距离越远偏移距离越大。

思路:首先获取图片原先的距离。设置一个变化值,图片的最终距离等于原先的距离加上变化值

布局:大盒子里面是图片,大盒子position:relative;图片position:absolute;

无标题文档

body{margin:0;}

#wrap{width:800px;height:500px;margin:30px auto; border:1px solid #000; position:relative;}

#wrap img{ position:absolute;}

#wrap img:nth-of-type(1){ left:200px;top:200px; z-index:0;}

#wrap img:nth-of-type(2){ left:300px;top:180px; z-index:1;}

#wrap img:nth-of-type(3){ left:100px;top:100px; z-index:2;}

#wrap img:nth-of-type(4){ left:400px;top:110px; z-index:3;}

var oWrap=document.getElementById("wrap");

var aImg=oWrap.getElementsByTagName("img");

var iMax=4;

//获取图片的初始位置

for(var i=0;i

aImg[i].startX=parseInt(getStyle(aImg[i],'left'))

}

oWrap.οnmοusemοve=function(ev){

ev=ev||window.event;

//获取鼠标的位置与大盒子中心点位置的距离

var iX=ev.clientX-(oWrap.offsetLeft+this.offsetWidth/2)

for(var i=0;i

//获取每个img的z-index

var iZindex=getStyle(aImg[i],'zIndex')

//Zindex越大移动的相对距离越小

var iDisL=-parseInt(iX/iMax*(iMax-iZindex)/5)

//图片的距离等于原先的距离加上计算的距离

aImg[i].style.left=aImg[i].startX+iDisL+'px'

}

}

function getStyle(obj,attr)

{

if( obj.currentStyle){

return obj.currentStyle[attr];

}

return getComputedStyle(obj)[attr];

}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

更多推荐

鼠标移动效果html5,js实现鼠标左右移动,图片也跟着移动效果

本文发布于:2023-07-03 20:07:57,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1011292.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:鼠标   效果   图片   js

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!