jQuery chili图片远处放大插件


Posted in Javascript onNovember 30, 2009

为了让本地图片、远程图片、过小的图片都适应此插件,有很多细节问题要处理。

首先定义结构:
<div class="imgMagnifierWrap"> 
<div class="overlay"><!--覆盖层,鼠标的感应区域,位于小图上最方--></div> 
<div class="tipboxHover"><!--小图上方的悬停提示方框--></div> 
<div class="imgOriginal"><!--装载大图的容器,绝对定位<img src="bigOne.jpg" /><!--前景大图,绝对定位--></div> 
</div>
<!--样式--> 
<style type="text/css"> 
.imgMagnifierWrap *{position:absolute;background:#fff;} 
.imgMagnifierWrap .tipboxHover{width:80px; height:60px; filter:alpha(opacity=30);opacity:.3;display:none;} 
.imgMagnifierWrap .imgOriginal{display:none;z-index:9999;overflow:hidden; width:400px; height:400px; 
    background-color:#cdf; background-repeat:no-repeat; text-align:center;border:1px solid #555; } 
.imgMagnifierWrap .overlay{cursor:crosshair;filter:alpha(opacity=0);opacity:0;} 
<style>
然后考虑图片预加载:
$.imgPreloader=function(url,eventLists){ 
var img=new Image(); 
var $img=$(img); 
img.src=url; 
$.each(eventLists,function(type,fn){ 
$img.bind(type,fn); 
}); 
$img.trigger(img.complete?'load':'begin'); 
return $img; 
};
再计算感应区域:
小图所处感应区域四边各减去指示方框各四边的1/2大小的矩形,在此之外的区域则显示到大图边界:
var borderLeft =thumbInfo.left+tipboxInfo.width/2; 
var ratioX=(mouseInfo.x-borderLeft)/(thumbInfo.width-tipboxInfo.width);
用大图用做背景图片引发的问题:
用隐藏的前景图片预加载,load事件判断时机,ie,chrome正常,ff请求了两次图片,图片未缓存;
换一种方式,不预载大图。改成直接在大图位置用覆盖层做“loading”后,chrome下表现为渐进加载图片,非chrome是直接显示,略有遗憾。
最终结果,把大图用做前景图片:
优势在于,大图的load和error事件都可以正常工作:
$.imgPreloader($anchor.attr('href'),{ 
load:function(){ 
isImageReady=true; 
$o.empty().append(this); 
setTimeout(autoFitPicture,0); 
}, 
begin:function(){ 
$o.text('loading...'); 
}, 
error:function(){ 
isImageReady=true; 
$o.text('invalid picture!'); 
} 
});

大图预载的load事件和小图mousemove事件不同步的解决办法:实时存储鼠标坐标,把提示方框定位和大图定位的方法分离。

//鼠标位置存储 
var mouseInfo={x:0,y:0}; 
//指示框定位 
var setTipboxPosition=function(e){ 
mouseInfo.x=e.pageX; 
mouseInfo.y=e.pageY; 
$tipbox.css({ 
top:mouseInfo.y<thumbInfo.width/2+thumbInfo.top 
?Math.max(mouseInfo.y-tipboxInfo.height/2,thumbInfo.top) 
:Math.min(mouseInfo.y-tipboxInfo.height/2,thumbInfo.top+thumbInfo.height-tipboxInfo.height), 
left:mouseInfo.x<thumbInfo.width/2+thumbInfo.left 
?Math.max(mouseInfo.x-tipboxInfo.width/2,thumbInfo.left) 
:Math.min(mouseInfo.x-tipboxInfo.width/2,thumbInfo.left+thumbInfo.width-tipboxInfo.width) 
});   
setImgPosition(); 
};

随便一提,如果有一种浏览器,也许会很幸运。
演示代码
打包下载 https://3water.com/jiaoben/22866.html

Javascript 相关文章推荐
jQuery Ajax文件上传(php)
Jun 16 Javascript
jquery eval解析JSON中的注意点介绍
Aug 23 Javascript
html5 canvas js(数字时钟)实例代码
Dec 23 Javascript
jquery修改网页背景颜色通过css方法实现
Jun 06 Javascript
JavaScript定时显示广告代码分享
Mar 02 Javascript
jQuery与Ajax以及序列化
Feb 01 Javascript
leaflet的开发入门教程
Nov 17 Javascript
vue.js绑定class和style样式(6)
Dec 09 Javascript
浅谈webpack 自动刷新与解析
Apr 09 Javascript
微信小程序上线发布流程图文详解
May 06 Javascript
ES6数组与对象的解构赋值详解
Jun 14 Javascript
node.js使用express-fileupload中间件实现文件上传
Jul 16 Javascript
document.body.scrollTop 值总为0的解决方法 比较常见的标准问题
Nov 30 #Javascript
javascript 设置某DIV区域内的checkbox复选框
Nov 30 #Javascript
Javascript 构造函数,公有,私有特权和静态成员定义方法
Nov 30 #Javascript
javascript &amp;&amp;和||运算法的另类使用技巧
Nov 28 #Javascript
javascript showModalDialog 多层模态窗口实现页面提交及刷新的代码
Nov 28 #Javascript
JavaScript 闭包在封装函数时的简单分析
Nov 28 #Javascript
extJs 文本框后面加上说明文字+下拉列表选中值后触发事件
Nov 27 #Javascript
You might like
PHP5中的this,self和parent关键字详解教程
2007/03/19 PHP
详谈php静态方法及普通方法的区别
2016/10/04 PHP
Redis在Laravel项目中的应用实例详解
2017/08/11 PHP
客户端脚本中常常出现的一些问题和调试技巧
2007/01/09 Javascript
jQuery ctrl+Enter shift+Enter实现代码
2010/02/07 Javascript
基于jQuery的图片不完全按比例自动缩小
2014/07/11 Javascript
jquery树形菜单效果的简单实例
2016/06/06 Javascript
Javascript中call,apply,bind方法的详解与总结
2016/12/12 Javascript
微信小程序 详解页面跳转与返回并回传数据
2017/02/13 Javascript
bootstrap IE8 兼容性处理
2017/03/22 Javascript
vue.js的安装方法
2017/05/12 Javascript
基于jQuery的表单填充实例
2017/08/22 jQuery
react中的ajax封装实例详解
2017/10/17 Javascript
基于JS实现一个随机生成验证码功能
2019/05/29 Javascript
React.js组件实现拖拽排序组件功能过程解析
2020/04/27 Javascript
vue项目使用$router.go(-1)返回时刷新原来的界面操作
2020/07/26 Javascript
Bootstrap告警框(alert)实现弹出效果和短暂显示后上浮消失的示例代码
2020/08/27 Javascript
[11:27]《一刀刀一天》之DOTA全时刻20:TI4总奖金突破920W TS赛事分析
2014/06/18 DOTA
[01:29]2017 DOTA2国际邀请赛官方英雄手办展示
2017/03/18 DOTA
[00:20]TI9观赛名额抽取Ⅱ
2019/07/24 DOTA
跟老齐学Python之折腾一下目录
2014/10/24 Python
Python编程入门的一些基本知识
2015/05/13 Python
python3 对list中每个元素进行处理的方法
2018/06/29 Python
详解Python中的分组函数groupby和itertools)
2018/07/11 Python
Python TKinter如何自动关闭主窗口
2020/02/26 Python
Html5内唤醒百度、高德APP的实现示例
2019/05/20 HTML / CSS
空字符串(“”)和null的区别
2012/11/13 面试题
大专学生推荐信范文
2013/11/19 职场文书
机电一体化专业应届生求职信
2013/11/27 职场文书
GMP办公室主任岗位职责
2014/03/14 职场文书
2014年十一国庆向国旗敬礼寄语
2014/04/11 职场文书
市场营销专业求职信
2014/06/17 职场文书
企业趣味活动方案
2014/08/21 职场文书
2015年卫生监督工作总结
2015/05/21 职场文书
公司备用金管理制度
2015/08/04 职场文书
详解CSS中的特指度和层叠问题
2021/07/15 HTML / CSS