开发者社区> 最美的回忆> 正文

原生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>
复制代码

            效果图(上图)

 本文转自挨踢前端博客园博客,原文链接http://www.cnblogs.com/duanhuajian/archive/2012/08/21/2650053.html如需转载请自行联系原作者


@挨踢前端

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
如何用原生js写一个懒加载页面带渐变效果
懒加载经常是我们性能优化经常使用的方案,那么我们今天就实现一波。
9 0
WPF放大镜效果
原文:WPF放大镜效果 在做WPF项目中,不止两个项目需要有放大镜功能。 第一个项目是一个手术室的远程示教系统,主要是为了方便专家演示病症时,可以放大图片上的某些部位。 第二个项目是一个工厂的MES项目,其中有个功能是质量预警,主要就是根据疵点图片,对比实物进行预警。
1057 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
18211 0
第54天:原生js实现轮播图效果
一、轮播图的原理: 一系列的大小相等的图片平铺,利用CSS布局只显示一张图片,其余隐藏。通过计算偏移量利用定时器实现自动播放,或通过手动点击事件切换图片。 二、Html布局     首先父容器container存放所有内容,子容器list存放图片。
1963 0
如何设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云安全组设置详细图文教程(收藏起来) 阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程。阿里云会要求客户设置安全组,如果不设置,阿里云会指定默认的安全组。那么,这个安全组是什么呢?顾名思义,就是为了服务器安全设置的。安全组其实就是一个虚拟的防火墙,可以让用户从端口、IP的维度来筛选对应服务器的访问者,从而形成一个云上的安全域。
15553 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
13666 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
23609 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
13826 0
WPF中利用RadialGradient模拟放大镜效果
原文:WPF中利用RadialGradient模拟放大镜效果 --------------------------------------------------------------------------------引用时请保留以下信息:大可山 [MSN:a3news(AT)hotmail.
824 0
2286
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载