基于Jquery插件开发之图片放大镜效果(仿淘宝)_Javascript教程-查字典教程网
基于Jquery插件开发之图片放大镜效果(仿淘宝)
基于Jquery插件开发之图片放大镜效果(仿淘宝)
发布时间:2016-12-30 来源:查字典编辑
摘要:需求:公司某个网站,需要实现图片预览效果,并能像淘宝一样实现局部分大!思索:为了考虑开发速度,最先考虑的是想使用网络上的现成代码!但是大致搜...

需求:公司某个网站,需要实现图片预览效果,并能像淘宝一样实现局部分大!

思索:为了考虑开发速度,最先考虑的是想使用网络上的现成代码!但是大致搜索了一下,网上可用的代码并不多,而且部分效果并不理想!而且有些代码,估计阅读下来比自己写一个成本还要高,于是产生了自己写一个jquery的插件的想法!

原理:最起考虑的原理是,两张图片,一张小图,一张大图,先获取鼠标在小图上面的坐标,然后以一个div来显示大图,并根据小图的坐标乘以大图除以小图得到的倍数定位!开始是把大图设为平铺不重复北景,然后使用背景的position属性来定位,理果比较理想,但是在IE6下面,图片存在闪烁,于是改成以图片的绝对定位方式显示!

效果图:

代码:

复制代码 代码如下:

/*

*

* JQUERY 之简易放大镜插件-JNMagnifier

* Author:翅膀的初衷

* QQ:4585839

* Date:2011-11-16

*

*/

(function($){

$.fn.JNMagnifier=function(setting){

if(setting&&setting.renderTo){

if(typeof(setting.renderTo)=="string"){

setting.renderTo = $(setting.renderTo);

}

}else{

return;

}

var _img_org_ = this.children("img");

_img_org_.css("cursor","pointer");

var __w = 0;

var __h = 0;

var __left = this.offset().left;

var __top = this.offset().top;

if(this.offsetParent())

{

__left+=this.offsetParent().offset().left;

__top+=this.offsetParent().offset().top;

}

var _move_x = 0;

var _move_y = 0;

var _val_w = (setting.renderTo.width() / 2);

var _val_h = (setting.renderTo.height() / 2);

_img_org_.mouseover(function(){

setting.renderTo.html('<img src="' + _img_org_.attr("src") + '" id="JNMagnifierrenderToImg" />');

setting.renderTo.show();

var timer = setInterval(function(){

__w = $("#JNMagnifierrenderToImg").width() / _img_org_.width();

__h = $("#JNMagnifierrenderToImg").height() /_img_org_.height();

if(__w>0){

clearInterval(timer);

}

},100);

});

_img_org_.mouseout(function(){

setting.renderTo.hide();

});

_img_org_.mousemove(function(e){

_move_x =0-Math.round((document.documentElement.scrollLeft+e.clientX-__left) * __w - _val_w);

_move_y =0-Math.round((document.documentElement.scrollTop+e.clientY-__top) * __h - _val_h);

$("#JNMagnifierrenderToImg").css({"left":_move_x + "px ","top":_move_y + "px"});

});

}

})(jQuery);

调用方法:

复制代码 代码如下:

$("#ShowPictureBox").JNMagnifier({

renderTo:"#ShowBigPictureBox"

});

HTML

复制代码 代码如下:

<div id="ShowPictureBox">

<img src="图片" width="200" height="200">

</div>

<div id="ShowBigPictureBox">

<>

</div>

注意事项:

这里没有使用两张图片,只用了一张图,图片为大图,长宽必须大于放大效果DIV的大小!默认放大倍数为原图与显示小图之间的倍数,如果需要控制放大倍数,可以手动的为“_img_org_.mouseover”事件中的图片设定对应的长宽就可以实现

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类