jquery图片放大镜效果
发布时间 - 2026-01-11 02:01:54 点击率:次昨天看一篇博文的时候,说到了这个效果,于是自己想试着写一个,没有使用插件,

基本的想法就是,左边是小图,右边对应大图,鼠标进去小图范围之后,获取他的坐标(x,y)然后计算
x/小图的宽度*大图得宽度/2
y/小图的高度*大图得高度/2
计算出来的两个结果即为大图得左右偏移距离
/2是为了让右边区域不会出现空白。
经过测试,ie7以上以及主流浏览器都可以用,代码如下:
<div class="wrap">
<div class="small">
<img src="1s.jpg">
<div class="tool" id="tool"></div>
</div>
<div class="big"><img src="1.jpg"></div>
</div>
.wrap{overflow:hidden;margin:50px auto;}
.small{position:relative;float:left;width:214px;height:328px;}
.tool{width:100px;height:100px;position:absolute;top:50px;left:100px;background:rgba(255,255,255,0.5);}
.big{float:left;margin:0 40px;width:330px;overflow:hidden;height:328px;display:none;position:relative;}
.big img{position:absolute;width:650px;height:960px;}
主要的JS代码如下:
//不加蒙版放大镜
$('.small').mousemove(function(e) {
$(this).siblings('.big').show();
//var e = event || window.event;
var scrollX = document.documentElement.scrollLeft || document.body.scrollLeft;
//滚动条距离屏幕左边的宽度
var scrollY = document.documentElement.scrollTop || document.body.scrollTop;
//滚动条距离屏幕上面的高度
//e.pageX相对于文档左边的高度
//e.pageY相对于文档上面的高度
//e.clientX相对于屏幕左边的高度
//e.clientY相对于屏幕上面的高度
var xx = e.pageX || e.clientX + scrollX;//相对于文档左边的宽度
var yy = e.pageY || e.clientY + scrollY;//相对于文档上面的高度
//.offset().top元素相对于文档上面的位置
//.offset().left元素相对于文档左面的位置
var y=yy-$(this).offset().top;//鼠标相对于元素的x,y坐标
var x=xx-$(this).offset().left;
var width=$(this).width();
var lwidth=$(this).siblings('.big').find('img').width();
//按照大图与小图的比例来进行移动的
var left=x/width*lwidth/2;
var height=$(this).height();
var lheight=$(this).siblings('.big').find('img').height();
var top=y/height*lheight/2;
$(this).siblings('.big').find('img').css({left:-left,top:-top});
//console.log(x + '---' + y);
//不加蒙版放大镜结束
//蒙版跟着动
var twidth=$(this).find('.tool').width();
var theight=$(this).find('.tool').height();
var tleft=x-twidth/2;
var ttop=y-theight/2;
if(tleft<0){
tleft=0;
}
if(tleft>width-twidth){
tleft=width-twidth;
}
if(ttop<0){
ttop=0
}
if(ttop>height-theight){
ttop=height-theight;
}
$(this).find('.tool').css({left:tleft,top:ttop});
});
效果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# jquery
# 放大镜
# jquery实现放大镜简洁代码(推荐)
# jQuery实现的放大镜效果示例
# 基于jquery编写的放大镜插件
# jQuery实现图片局部放大镜效果
# jQuery实现放大镜效果实例代码
# 基于jQuery仿淘宝产品图片放大镜特效
# 基于jQuery实现放大镜特效
# jquery实现图片放大镜功能
# 基于jQuery仿淘宝产品图片放大镜代码分享
# 基于jquery实现放大镜效果
# 使用jquery实现放大镜效果
# jquery放大镜效果超漂亮噢
# jquery图片放大镜功能的实例代码
# 基于jquery的放大镜效果
# 实现jquery放大镜的两种方法
# 相对于
# 文档
# 小图
# 鼠标
# 不加
# 滚动条
# 可以用
# 试着
# 即为
# 大家多多
# 是为了
# 博文
# 昨天
# css
# overflow
# margin
# hidden
# jpg
# src
# tool
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
IOS倒计时设置UIButton标题title的抖动问题
Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解
Laravel如何实现用户密码重置功能?(完整流程代码)
HTML 中动态设置元素 name 属性的正确语法详解
C++时间戳转换成日期时间的步骤和示例代码
如何为不同团队 ID 动态生成多个独立按钮
如何用花生壳三步快速搭建专属网站?
猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
浅谈javascript alert和confirm的美化
5种Android数据存储方式汇总
Laravel安装步骤详细教程_Laravel环境搭建指南
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
如何在阿里云购买域名并搭建网站?
html5audio标签播放结束怎么触发事件_onended回调方法【教程】
香港服务器如何优化才能显著提升网站加载速度?
Bootstrap CSS布局之列表
网站建设要注意的标准 促进网站用户好感度!
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
简单实现Android验证码
Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决
HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】
高端网站建设与定制开发一站式解决方案 中企动力
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
如何用JavaScript实现文本编辑器_光标和选区怎么处理
Android利用动画实现背景逐渐变暗
如何注册花生壳免费域名并搭建个人网站?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
Java解压缩zip - 解压缩多个文件或文件夹实例
Python函数文档自动校验_规范解析【教程】
零基础网站服务器架设实战:轻量应用与域名解析配置指南
Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程
企业网站制作这些问题要关注
如何快速使用云服务器搭建个人网站?
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
iOS UIView常见属性方法小结
C语言设计一个闪闪的圣诞树
PHP正则匹配日期和时间(时间戳转换)的实例代码
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
如何快速启动建站代理加盟业务?

