我是靠谱客的博主 辛勤向日葵,这篇文章主要介绍jquery实现图片放大镜效果,现在分享给大家,希望可以做个参考。

本文实例为大家分享了jquery实现图片放大镜效果的具体代码,供大家参考,具体内容如下

首先是HTML

复制代码
1
2
3
4
5
6
7
8
9
10
11
<div id="box"> <div id="big"> <div> <img src="./img/可达鸭.jpg" alt=""> </div> <div id="fd"></div> </div> <div id="fdshow"> <img src="./img/可达鸭.jpg" alt=""> </div> </div>

这里主要是放入两张照片,和一个空的标签,用于放大用

接下来是css样式,这里非常重要,能不能成功放大这里占据了6成左右

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<style> *{ margin: 0px; padding: 0px; } #box{ position: relative; } #big{ width: 500px; height: 300px; } #big img{ width: 500px; height: 300px; } #fd{ width: 100px; height: 100px; background-color: white; opacity: 0.4; position: absolute; top: 0; left: 0; display: none; } #fdshow{ width: 200px; height: 200px; overflow: hidden; position: relative; border: 1px solid; } #fdshow>img{ width: 1000px; height: 600px; position: absolute; top: 0px; left: 0px; } </style>

接下来是jq

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<script> $("#big img").on("mousemove",function(a){ var x=a.pageX-$("#big").offset().left; var y=a.pageY-$("#big").offset().top; console.log(x,y) var style1={ top:y, left:x, "display":"block" }; $("#fd").css(style1); var style2={ 'left':-2*x, 'top':-2*y }; $("#fdshow>img").css(style2) }) </script>

效果达到放大2倍 (对css样式的要求特别严格)

1.css 样式 大图片是小图片的2倍

2.给大图片外面套一个div设置一个是那个选图片的div的2倍,然后给大图片的div设置一个溢出部分隐藏 overflow: hidden;

3.获取鼠标在元素内的位置

(1).获取鼠标相对于文档的位置
(2).然后在获取元素的在当前可视区域的位置
(3).鼠标在元素内的位置 == 鼠标相对于文档的位置 减 获取元素的在当前可视区域的位置

4.给放大镜框添加位置 就是鼠标在元素内的位置这一步就达到了放大镜框跟这鼠标走

5.给大图片添加 top left值 就是偏移量

e ==> js中的 event
获取鼠标在元素内的位置

(1).获取鼠标相对于文档的位置
(2).然后在获取元素的在当前可视区域的位置
(3).鼠标在元素内的位置 == 鼠标相对于文档的位置 减 获取元素的在当前可视区域的位置
因为上面css样式中写入的 大图片是小图片的2倍 所以这里的偏移变应该也是2倍

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持靠谱客。

最后

以上就是辛勤向日葵最近收集整理的关于jquery实现图片放大镜效果的全部内容,更多相关jquery实现图片放大镜效果内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(129)

评论列表共有 0 条评论

立即
投稿
返回
顶部