原生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如需转载请自行联系原作者


@挨踢前端

相关文章
|
4天前
|
移动开发 前端开发 JavaScript
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
于辰在大学期间带领团队参考网易游戏官网的部分游戏页面,开发了一系列前端实训作品。项目包括首页、2021校园招聘页面和明日之后游戏页面,涉及多种特效实现,如动态图片切换和人物聚合效果。作品源码已上传至CSDN,视频效果可在CSDN预览。
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
|
2月前
|
移动开发 前端开发 JavaScript
原生JavaScript+canvas实现五子棋游戏_值得一看
本文介绍了如何使用原生JavaScript和HTML5的Canvas API实现五子棋游戏,包括棋盘的绘制、棋子的生成和落子、以及判断胜负的逻辑,提供了详细的代码和注释。
30 0
原生JavaScript+canvas实现五子棋游戏_值得一看
|
3月前
|
Devops 持续交付 测试技术
JSF遇上DevOps:开发流程将迎巨变?一篇文章带你领略高效协同的魅力!
【8月更文挑战第31天】本文探讨了如何在JavaServer Faces(JSF)开发中融入DevOps文化,通过持续集成与部署、自动化测试、监控与日志记录及反馈机制,提升软件交付速度与质量。文中详细介绍了使用Jenkins进行自动化部署、JUnit与Selenium进行自动化测试、ELK Stack进行日志监控的具体方法,并强调了持续改进的重要性。
38 0
|
3月前
|
JavaScript 前端开发 API
从零开始学表单操作,jQuery 与原生 JavaScript 完全指南,带你轻松掌握网页交互关键!
【8月更文挑战第31天】在网页开发中,表单是实现用户互动的关键元素。无论是收集信息、提交数据还是验证输入,都需要对表单进行有效操作。本文档介绍了如何使用原生 JavaScript 和 jQuery 操作表单,包括获取表单元素、读写表单值、处理表单提交及验证等核心功能。jQuery 提供了更简洁的语法和更好的兼容性,但原生 JavaScript 在性能上有优势。选择合适的方法取决于项目需求和个人偏好。下面通过具体示例展示了两种方式的操作方法。
32 0
|
5月前
|
JavaScript 前端开发 安全
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
|
5月前
|
JavaScript
原生JS实现全选、全不选
原生JS实现全选、全不选
|
4月前
|
JavaScript
js 一键复制到剪贴板(原生js实现)
js 一键复制到剪贴板(原生js实现)
31 0
|
5月前
|
前端开发 JavaScript 容器
程序技术好文:纯原生javascript下拉框表单美化实例教程
程序技术好文:纯原生javascript下拉框表单美化实例教程
82 0
|
5月前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
201 0
|
5月前
|
JavaScript 前端开发
原生JS如何查询元素属性
原生JS如何查询元素属性
39 0