jQuery实现放大镜效果实例代码

在没给大家做详细文字说明之前,先给大家分享一段简单的jquery实现放大镜效果代码,需要的朋友可以直接拿去代码。

$(function(){ var mouseX = 0; //鼠标移动的位置X var mouseY = 0; //鼠标移动的位置Y var maxLeft = 0; //最右边 var maxTop = 0; //最下边 var markLeft = 0; //放大镜移动的左部距离 var markTop = 0; //放大镜移动的顶部距离 var perX = 0; //移动的X百分比 var perY = 0; //移动的Y百分比 var bigLeft = 0; //大图要移动left的距离 var bigTop = 0; //大图要移动top的距离 //改变放大镜的位置 function updataMark($mark){ //通过判断,让小框只能在小图区域中移动 if(markLeft<0){ markLeft = 0; }else if(markLeft>maxLeft){ markLeft = maxLeft; } if(markTop<0){ markTop = 0; }else if(markTop>maxTop){ markTop = maxTop; } //获取放大镜的移动比例,即这个小框在区域中移动的比例 perX = markLeft/$(".small").outerWidth(); perY = markTop/$(".small").outerHeight(); bigLeft = -perX*$(".big").outerWidth(); bigTop = -perY*$(".big").outerHeight(); //设定小框的位置 $mark.css({"left":markLeft,"top":markTop,"display":"block"}); } //改变大图的位置 function updataBig(){ $(".big").css({"display":"block","left":bigLeft,"top":bigTop}); } //鼠标移出时 function cancle(){ $(".big").css({"display":"none"}); $(".mark").css({"display":"none"}); } //鼠标小图上移动时 function imgMouseMove(event){ var $this = $(this); var $mark = $(this).children(".mark"); //鼠标在小图的位置 mouseX = event.pageX-$this.offset().left - $mark.outerWidth()/2; mouseY = event.pageY-$this.offset().top - $mark.outerHeight()/2; //最大值 maxLeft =$this.width()- $mark.outerWidth(); maxTop =$this.height()- $mark.outerHeight(); markLeft = mouseX; markTop = mouseY; updataMark($mark); updataBig(); } $(".small").bind("mousemove",imgMouseMove).bind("mouseleave",cancle); })

需要注意这个里面主要有二点

1.如何大图跟随"放大镜"的位置,同时移动大图?

其实就是用到一个比例关系,当“放大镜”移动多少比例(是比例,不是具体值),大图也同时用这个比例去乘以大图的宽和高,就可以算出大图该移动多少距离了;

2.显示区域和放大镜的关系?

这里的“放大镜”应该和大图的显示区域的比例,应该是大图和小的比例关系一样。比如大图和小图的比例是1:2,那个“放大镜”区域的大小,和显示大图区域的大小比例也应该是1:2,不然“放大镜”罩住的小图区域,和大图的显示区域,所显示的图像信息,不能保持一致。(妙味课堂里讲的那个实例,就是没有保持一至);

好了,以上代码还算比较简单,下面给大家通过文字说明加代码的形式给大家介绍jquery实现放大镜效果。

1.1.1 摘要

相信大家都见过或使用过放大镜效果,甚至实现过该效果,它一般应用于放大查看商品图片,一些电商网站(例如:凡客,京东商城,阿里巴巴等)都有类似的图片查看效果。

在接下来的博文中,我们将向大家介绍通过jQuery实现放大镜效果。

目录

•实现原理

•mousemove事件

•相对坐标

•background-position属性

•mousewheel事件

1.1.2 正文

实现原理

首先,我们讲解一下放大镜效果的实现方式:

方法一:准备一张高像素的大图,当鼠标放到原图上,加载显示大图的对应位置。

方法二:对原图片进行放大,也就是调整原图的长和宽。

上面我们介绍了通过两种方式实现放大镜效果,接下来,我们将以上的两种方式应用到我们的jQuery插件中。

首先,我们需要一个img元素显示原图对象,还需要一个容器作为显示框;显示框里面存放大图对象。当鼠标移动到原图上时,通过对大图进行绝对定位来显示对应的部位,实现类似放大镜的效果。

接下来,让我们定义Index.html页面,具体实现如下:

<!doctype html> <html lang="en-US"> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <title>jQuery Image Zoom Demo</title> <meta content="Jackson Huang"> </head> <body> <div> <div></div> <img src="https://www.jb51.net/article/img/1.jpg" /> </div> </body> </html>

上面,我们定义了small对象用于显示原图,而large对象作为一个显示框用来显示大图的对应位置。

mousemove事件

接下来,我们通过jQuery插件形式来实现放大镜效果,当鼠标移动到small对象上方时,就会在large对象中显示大图的对应位置,这就涉及到mousemove事件了,所以,我们需要实现mousemove事件的监听方法(如何定义jQuery插件可以参考《自定义jQuery插件Step by Step》)。

现在,让我们实现jquery.imagezoom.js插件吧!

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wgyjdx.html