• 原生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{200px;height:150px;position:relative;margin:20px auto;}
    15 .inner{80px;height:60px;background:#f55;position:absolute;opacity:0.5;filter:alpha(opacity=50);left:0;top:0;cursor:pointer;}
    16 .aa{320px;height:240px;position:relative;border:1px red solid;margin:20px auto;overflow:hidden;}
    17 .imgs{position:absolute;}
    18 .outer img{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>

                效果图(上图)

  • 相关阅读:
    C语言的异常处理
    单例类模板
    智能指针模板
    数组类指针
    类模板
    函数模板
    shell 修改工作路径
    把目录C:Python34PCI_Codechapter2加到系统路径中
    twoSum
    归并排序
  • 原文地址:https://www.cnblogs.com/duanhuajian/p/2650053.html
Copyright © 2020-2023  润新知