您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。