jquery实现图片放大镜效果
(编辑:jimmy 日期: 2025/10/25 浏览:3 次 )
本文实例为大家分享了jquery实现图片放大镜效果的具体代码,供大家参考,具体内容如下
首先是HTML
<div id="box">
<div id="big">
<div>
<img src="/UploadFiles/2021-04-02/可达鸭.jpg">
这里主要是放入两张照片,和一个空的标签,用于放大用
接下来是css样式,这里非常重要,能不能成功放大这里占据了6成左右
<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
<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倍
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇:解决基于 keep-alive 的后台多级路由缓存问题