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开发环境  如何构建满足综合性能需求的优质建站方案?  如何在建站宝盒中设置产品搜索功能?