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管理数据库结构的正确姿势  如何快速启动建站代理加盟业务?