您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
这篇文章将为大家详细讲解有关js如何实现鼠标左右移动图片也跟着移动的效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
效果:鼠标往左移,图片对应右移,鼠标往右移,图片就左移动。图片距离越远偏移距离越大。
思路:首先获取图片原先的距离。设置一个变化值,图片的最终距离等于原先的距离加上变化值
布局:大盒子里面是图片,大盒子position:relative;图片position:absolute;
<!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> <style> 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;} </style> </head> <body> <div id="wrap"> <img src="https://cache.yisu.com/upload/information/20200622/114/77545.jpg.editor.jpg" /> <img src="https://cache.yisu.com/upload/information/20200622/114/77546.jpg.editor.jpg" /> <img src="https://cache.yisu.com/upload/information/20200622/114/77547.jpg.editor.jpg" /> <img src="https://cache.yisu.com/upload/information/20200622/114/77547.jpg.editor.jpg" /> </div> <script> var oWrap=document.getElementById("wrap"); var aImg=oWrap.getElementsByTagName("img"); var iMax=4; //获取图片的初始位置 for(var i=0;i<aImg.length;i++){ aImg[i].startX=parseInt(getStyle(aImg[i],'left')) } oWrap.onmousemove=function(ev){ ev=ev||window.event; //获取鼠标的位置与大盒子中心点位置的距离 var iX=ev.clientX-(oWrap.offsetLeft+this.offsetWidth/2) for(var i=0;i<aImg.length;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]; } </script> </body> </html>
关于“js如何实现鼠标左右移动图片也跟着移动的效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。