最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
js实现鼠标左右移动,图片也跟着移动效果
时间:2017-03-07 编辑:简简单单 来源:一聚教程网
效果:鼠标往左移,图片对应右移,鼠标往右移,图片就左移动。图片距离越远偏移距离越大。
思路:首先获取图片原先的距离。设置一个变化值,图片的最终距离等于原先的距离加上变化值
布局:大盒子里面是图片,大盒子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.onmousemove=function(ev){ ev=ev||window.event; //获取鼠标的位置与大盒子中心点位置的距离 variX=ev.clientX-(oWrap.offsetLeft+this.offsetWidth/2) for(vari=0;i //获取每个img的z-index variZindex=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]; } |
相关文章
- js 可控图片左右滑动代码 04-17
- HTML简单购物数量小程序代码展示 10-31
- html canvas实现弹幕功能 10-31
- HTML中空格表示的意义 10-31
- html area标签解读 10-31
- html使用表单标签实现注册页面代码展示 10-31