需求:公司某个网站,需要实现图片预览效果,并能像淘宝一样实现局部分大!
思索:为了考虑开发速度,最先考虑的是想使用网络上的现成代码!但是大致搜索了一下,网上可用的代码并不多,而且部分效果并不理想!而且有些代码,估计阅读下来比自己写一个成本还要高,于是产生了自己写一个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('');
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的大小!默认放大倍数为原图与显示小图之间的倍数,如果需要控制放大倍数,可以手动的为“_img_org_.mouseover” 事件中的图片设定对应的长宽就可以实现