这篇文章给大家分享的是有关原生JS怎么实现放大镜效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
10多年的商城网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。全网整合营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整商城建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“商城网站设计”,“商城网站推广”以来,每个客户项目都认真落实执行。
具体内容如下
<html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { margin: 0; padding: 0; } img{ vertical-align: top; } .fdj { width: 350px; height: 350px; position: relative; margin: 100px auto; border: 1px solid gainsboro; } .small { position: relative; } .small img { width: 350px; } .mask { width: 100px; height: 100px; background: rgba(255, 255, 0, 0.4); position: absolute; left: 0; top: 0; cursor: move; display: none; } .big { position: absolute; top: 0; left: 360px; width: 500px; height: 500px; border: 1px solid gainsboro; overflow: hidden; display: none; } .big img{ position: absolute; left: 0; top: 0; } </style> </head> <body> <div class="fdj"> <div class="small"> <img src="http://cdn.attach.qdfuns.com/notes/pics/201702/08/162503mw0fawb5b02va22i.jpg" /> <div class="mask"></div> </div> <div class="big"> <img src="http://cdn.attach.qdfuns.com/notes/pics/201702/08/162503mw0fawb5b02va22i.jpg" /> </div> </div> </body> <script type="text/javascript"> var fdj = document.querySelector('.fdj') // 获得最大的盒子 var small = document.querySelector('.small'); //获取小图片盒子 var big = document.querySelector('.big'); //获取大图片盒子 var bigs = big.children[0] //大图片 var smalls = small.children[0] //小图片 var mask = small.children[1]; //遮罩 //鼠标移入小图片盒子 small.onmouseover = function() { //鼠标移入图片盒子将遮罩与大图片显示 mask.style.display = 'block'; big.style.display = ' block'; }; //鼠标移出小图片盒子 small.onmouseout = function() { //鼠标移出小图片盒子将遮罩与大图片隐藏 mask.style.display = 'none'; big.style.display = 'none'; }; var x=0; var y=0; //鼠标在小图片上移动时 small.onmousemove = function(ev) { var ev = event || window.event; //让鼠标在遮罩正中 //鼠标X坐标与Y坐标 x = ev.clientX -this.offsetParent.offsetLeft- mask.offsetWidth / 2 ; y = ev.clientY -this.offsetParent.offsetTop- mask.offsetHeight / 2 ; //将遮罩限制在小图片盒子中 if (x<0) { x=0; }else if(x>small.offsetWidth-mask.offsetWidth){ x = small.offsetWidth-mask.offsetWidth; } if(y<0){ y=0; }else if(y>small.offsetHeight-mask.offsetHeight){ y= small.offsetHeight-mask.offsetHeight } mask.style.left = x + 'px'; mask.style.top = y + 'px'; //大图与小图的比例 /*var scalX = bigs.offsetWidth/small.offsetWidth; var scalY = bigs.offsetHeight/small.offsetHeight;*/ var scalX = x/(small.offsetWidth-mask.offsetWidth); var scalY = y/(small.offsetHeight-mask.offsetHeight); bigs.style.left = -(x*scalX)+'px'; bigs.style.top = -(y*scalY)+'px'; }; </script> </html>
效果图:(演示)
感谢各位的阅读!关于“原生JS怎么实现放大镜效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
分享题目:原生JS怎么实现放大镜效果
网页地址:https://www.cdcxhl.com/article16/pgdegg.html
成都网站建设公司_创新互联,为您提供做网站、网站设计、营销型网站建设、域名注册、动态网站、标签优化
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联