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 】
相关推荐:
Linux系统命令中tree命令详解
网站图片在线制作软件,怎么在图片上做链接?
如何有效防御Web建站篡改攻击?
lovemo网页版地址 lovemo官网手机登录
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
Python结构化数据采集_字段抽取解析【教程】
Laravel如何使用Vite进行前端资源打包?(配置示例)
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
javascript基于原型链的继承及call和apply函数用法分析
公司网站制作需要多少钱,找人做公司网站需要多少钱?
Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】
如何在腾讯云服务器上快速搭建个人网站?
如何为不同团队 ID 动态生成多个非值班状态按钮
如何在万网利用已有域名快速建站?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
Python文本处理实践_日志清洗解析【指导】
如何在万网主机上快速搭建网站?
如何在IIS中新建站点并解决端口绑定冲突?
如何在企业微信快速生成手机电脑官网?
济南网站建设制作公司,室内设计网站一般都有哪些功能?
使用豆包 AI 辅助进行简单网页 HTML 结构设计
Laravel如何生成URL和重定向?(路由助手函数)
高性价比服务器租赁——企业级配置与24小时运维服务
html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】
Laravel如何使用Sanctum进行API认证?(SPA实战)
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
简单实现Android文件上传
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
JavaScript如何实现错误处理_try...catch如何捕获异常?
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
详解jQuery中的事件
如何用IIS7快速搭建并优化网站站点?
用yum安装MySQLdb模块的步骤方法
b2c电商网站制作流程,b2c水平综合的电商平台?
Android GridView 滑动条设置一直显示状态(推荐)
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
Laravel如何集成Inertia.js与Vue/React?(安装配置)
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
如何构建满足综合性能需求的优质建站方案?
如何在建站宝盒中设置产品搜索功能?

