原生js--放大鏡效果


  在淘寶上購物時,總會看到類似放大鏡的效果。以下為原生js寫的一個放大鏡效果,其中肯定有很多不足,請大牛們指正,謝啦!

  我的大體思路是:時時監聽鼠標的坐標,當鼠標移動時,透明層隨着鼠標移動,大圖片相對透明層的移動而移動。不廢話了,看代碼。

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>放大鏡</title>
 6 <meta name="Keywords" content="">
 7 <meta name="author" content="@my_programmer">
 8 <style type="text/css">
 9 /*重置{*/
10 html{color:#000;background:#fff;}
11 body,div{padding:0;margin:0;}
12 img{border:none;}
13 /*}重置*/
14 .outer{width:200px;height:150px;position:relative;margin:20px auto;}
15 .inner{width:80px;height:60px;background:#f55;position:absolute;opacity:0.5;filter:alpha(opacity=50);left:0;top:0;cursor:pointer;}
16 .aa{width:320px;height:240px;position:relative;border:1px red solid;margin:20px auto;overflow:hidden;}
17 .imgs{position:absolute;}
18 .outer img{width:200px;height:150px;}
19 </style>
20 </head>
21 <body>
22     <div>
23         <div class="outer" id="outer">
24             <img src="images/pobabyb.gif" alt="pobaby小圖"/>
25             <div class="inner" id="inner"></div>
26         </div>
27         <div class="aa" id="aa">
28             <div class="imgs" id="imgs" ><img src="images/pobabyb.gif" alt="pobaby大圖"/></div>
29         </div>
30     </div>
31 <script type="text/javascript">
32     var outer=document.getElementById("outer");
33     var inner=document.getElementById("inner");
34     var aa=document.getElementById("aa");
35     var imgs=document.getElementById("imgs");
36     var x,y,n=false;
37     inner.onmousedown=test1;//如果把inner改為document,鼠標在窗口任意位置點擊,圖片都會跟隨
38     document.onmousemove=test2;//document如果改為outer,鼠標在outer內才起作用
39     document.onmouseup=test3;
40     function test1(event){//鼠標按下時方法
41         var event=event || window.event;//調試兼容,各個瀏覽器認識event有差別.
42         n=true;//當n=true(n的值可隨便設定)時,假定為鼠標按下的事件
43         x=event.clientX-inner.offsetLeft;//鼠標在透明層的相對橫坐標=鼠標坐標-方塊左邊距
44         y=event.clientY-inner.offsetTop;//鼠標在透明層的相對縱坐標=鼠標坐標-方塊上邊距
45     }
46     function test2(event){//鼠標移動時方法
47         var event=event || window.event;
48         if(n==true){
49             ////////鼠標移動范圍
50             inner.style.left=event.clientX-x+"px";
51             inner.style.top=event.clientY-y+"px";
52             ////////圖片移動范圍
53             imgs.style.left=-4*parseInt(inner.style.left)+"px";
54             imgs.style.top=-4*parseInt(inner.style.top)+"px";
55             ////////////////////////////限定鼠標移動的范圍
56             if(parseInt(inner.style.left)<0){
57                 inner.style.left=0+"px";
58             }
59             if(parseInt(inner.style.top)<0){
60                 inner.style.top=0+"px";
61             }
62             if(parseInt(inner.style.left)>outer.clientWidth-inner.clientWidth){
63                 inner.style.left=outer.clientWidth-inner.clientWidth+"px";
64             }
65             if(parseInt(inner.style.top)>outer.clientHeight-inner.clientHeight){
66                 inner.style.top=outer.clientHeight-inner.clientHeight+"px";
67             }
68             //////////////////////////////限定圖片移動的范圍
69             if(parseInt(imgs.style.left)>0){
70                 imgs.style.left=0+"px";
71             }
72             if(parseInt(imgs.style.top)>0){
73                 imgs.style.top=0+"px";
74             }
75             if(parseInt(imgs.style.left)<-4*(outer.clientWidth-inner.clientWidth)){
76                 imgs.style.left=-4*parseInt(outer.clientWidth-inner.clientWidth)+"px";
77             }
78             if(parseInt(imgs.style.top)<-4*(outer.clientHeight-inner.clientHeight)){
79                 imgs.style.top=-4*parseInt(outer.clientHeight-inner.clientHeight)+"px";
80             }
81         }
82     }
83     function test3(){//鼠標松開時方法
84         n=false;
85     }
86 </script>
87 </body>
88 </html>

            效果圖(上圖)

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM