使用JS怎样实现放大镜的功能,要点有哪些
Admin 2022-07-02 群英技术资讯 508 次浏览
本文实例为大家分享了JavaScript实现放大镜效果的具体代码,供大家参考,具体内容如下
这次实现的效果如下:
这次的案例稍微有一点难度,在css和js上都需要多加思考,话不多说,让我们来开始吧~
1、首先我们需要使用html和css规划好整体的布局,即两个相邻的盒子A和B,左边的盒子A中还有一个小盒子S。为了实现相邻,我采用的方法是为其均设置position:absolute
,然后设置left
和top
的值来使其相邻。
小盒子S我们同样可以为其设置position:absolute
,调整一下背景颜色即可。
2、然后我们需要使用js来设置动画效果,即:鼠标放在盒子A上时,小盒子S的位置会随着鼠标的移动发生移动,同时盒子B中的图像会成为盒子S覆盖图像的放大版。如何实现呢?
3、首先实现小盒子S的位置变化:调用盒子A的onmousemove
函数,传入参数client,表示时间鼠标在盒子A上移动。我们通过client获取鼠标的位置(clientX,clientY),然后通过(clientX-boxA.offsetLeft,clientY-boxA.offsetTop)
可获得鼠标在图像上的相对坐标,通过此值减去盒子S的宽度、高度的一半即可获得盒子S在A中的位置。
但是要注意,记得为盒子S设置边界,当横坐标为0或为A盒子宽度、纵坐标为0或者A盒子高度时,要使其坐标固定。
4、接着实现盒子B中的图像会成为盒子S覆盖图像的放大版:我们首先来思考一个问题,这个放大效果如何才能实现呢? 从我的实现角度出发,对于盒子B来说,它首先需要一个背景图==盒子A中的图像,然后将其放大某个倍数x,当盒子S移动时,改变B的background-position
为y,达到放大+移动的效果。
5、最后一点,x和y的值是多少呢?(假定S、A、B均为等比例) x:将盒子B放大的倍数应该等同于A的大小除以S的大小,这样能达到相同的图像范围。y:B移动时的距离变化应该示盒子S移动的距离*(盒子B的大小除以S的大小)。可以多加思考~
可能我的实现方法过程比较复杂,大家如果想到更好的方法可以留言呀
代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> * { margin: 0; padding: 0; } #box { position: absolute; left: 180px; top: 100px; } #box img { width: 400px; height: 300px; border: 1px solid rgba(255, 255, 255, 0.7); vertical-align: bottom; } #nav { width: 480px; height: 360px; border: 1px solid rgba(255, 255, 255, 0.7); position: absolute; left: 582px; top: 100px; background-image: url(../img/morn.jpg); background-repeat: no-repeat; background-size: 250% 250% } #small { width: 160px; height: 120px; position: absolute; } </style> </head> <body> <div id="box"> <div id="small"></div> <img src="../img/morn.jpg" alt=""> </div> <div id="nav"></div> <script> let box = document.getElementById("box"); let small = document.getElementById("small"); let nav = document.getElementById("nav"); box.onmousemove = function (client) { let x = client.clientX - box.offsetLeft; let y = client.clientY - box.offsetTop; small.style.left = x - 80 + 'px'; small.style.top = y - 60 + 'px'; let dis_x = box.offsetLeft + box.offsetWidth - client.clientX; let dis_y = box.offsetTop + box.offsetHeight - client.clientY; nav.style.backgroundPositionX = (80 - x) * 3 + 'px'; nav.style.backgroundPositionY = (60 - y) * 3 + 'px'; if (x - 80 < 0) { small.style.left = 0; nav.style.backgroundPositionX = 0; } if (dis_x <= 80) { small.style.left = box.offsetWidth - 160 + 'px'; nav.style.backgroundPositionX = (160 - box.offsetWidth) * 3 + 'px'; } if (y - 60 < 0) { small.style.top = 0; nav.style.backgroundPositionY = 0; } if (dis_y < 60) { small.style.top = box.offsetHeight - 120 + 'px'; nav.style.backgroundPositionY = (120 - box.offsetHeight) * 3 + 'px'; } small.style.backgroundColor = "rgba(135, 207, 235, 0.61)"; } box.onmouseout = function () { small.style.backgroundColor="transparent" } </script> </body> </html>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是有关用js实现淘宝图片切换的效果的内容,这个效果我们常常能在商城网站上看到,小编觉得挺实用的,因此分享给大家做个参考,感兴趣的朋友就跟随小编一起来看看吧。
react在linux上部署的方法:1、打开配置文件;2、通过“tar -zcvf client.tar.gz client”命令将client和server打包;3、将“client.tar.gz”,“server.tar.gz”,“theme.js”及“package.json”文件拷贝至服务器上的项目文件夹下;4、开启服务即可。
这篇文章给大家分享的是JS中splice方法的相关内容,splice()方法可以用于删除指定数量的元素,文中详细的介绍了 splice()方法的使用,有需要的朋友可以了解看看,接下来就跟随小编一起学习一下吧。
TypeScript语法详解之类型操作的补充 目录 类型操作的补充 类型断言的使用 非空类型的断言 可选链使用介绍 两个特殊操作符 字面量类型介绍 字面量推理介绍 总结 类型操作的补充 类型断言的使用 有时候TypeScript无法获取具体的类型信息,这个我们需要使用类型断言( Type Assertions). 比如我们在操作DOM的时候, 通过 document.getElementById 获取元素, TypeScript只知道该函数会返回HTMLElement ,但并不知道它具体的类型, 是无法得知具体是img还是div等等: 当我
我们在访问一些网站的时候,经常能看到一些自动弹出和关闭的广告,也就是广告自动出现几秒又消失的效果,接下来小编就给大家介绍怎样用来实现这一功能。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008