昨天看一篇博文的时候,说到了这个效果,于是自己想试着写一个,没有使用插件,

基本的想法就是,左边是小图,右边对应大图,鼠标进去小图范围之后,获取他的坐标(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
相关文章:
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
Android自定义控件实现温度旋转按钮效果
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
建站主机是什么?如何选择适合的建站主机?
c# 在ASP.NET Core中管理和取消后台任务
大型企业网站制作流程,做网站需要注册公司吗?
如何选择美橙互联多站合一建站方案?
已有域名如何免费搭建网站?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
存储型VPS适合搭建中小型网站吗?
青岛网站建设如何选择本地服务器?
如何通过IIS搭建网站并配置访问权限?
香港服务器如何优化才能显著提升网站加载速度?
招商网站制作流程,网站招商广告语?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
建站之星安装后界面空白如何解决?
建站之星导航如何优化提升用户体验?
如何快速生成ASP一键建站模板并优化安全性?
广东企业建站网站优化与SEO营销核心策略指南
如何自定义建站之星模板颜色并下载新样式?
python的本地网站制作,如何创建本地站点?
建站之星下载版如何获取与安装?
平台云上自主建站:模板化设计与智能工具打造高效网站
建站之星导航配置指南:自助建站与SEO优化全解析
建站主机选哪种环境更利于SEO优化?
如何在IIS中配置站点IP、端口及主机头?
西安专业网站制作公司有哪些,陕西省建行官方网站?
小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化
济南网站建设制作公司,室内设计网站一般都有哪些功能?
已有域名如何快速搭建专属网站?
如何通过智能用户系统一键生成高效建站方案?
如何选择高性价比服务器搭建个人网站?
如何在万网自助建站平台快速创建网站?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
如何快速重置建站主机并恢复默认配置?
网站制作员失业,怎样查看自己网站的注册者?
如何配置WinSCP新建站点的密钥验证步骤?
太原网站制作公司有哪些,网约车营运证查询官网?
实例解析angularjs的filter过滤器
如何快速生成专业多端适配建站电话?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
ui设计制作网站有哪些,手机UI设计网址吗?
制作国外网站的软件,国外有哪些比较优质的网站推荐?
PHP 500报错的快速解决方法
盘锦网站制作公司,盘锦大洼有多少5G网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。