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

基本的想法就是,左边是小图,右边对应大图,鼠标进去小图范围之后,获取他的坐标(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
相关文章:
外贸公司网站制作,外贸网站建设一般有哪些步骤?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
已有域名和空间如何搭建网站?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
建站之星好吗?新手能否轻松上手建站?
建站之星安装提示数据库无法连接如何解决?
如何用y主机助手快速搭建网站?
山东网站制作公司有哪些,山东大源集团官网?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
公司网站设计制作厂家,怎么创建自己的一个网站?
韩国服务器如何优化跨境访问实现高效连接?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
宿州网站制作公司兴策,安徽省低保查询网站?
Swift中swift中的switch 语句
如何在香港免费服务器上快速搭建网站?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
如何高效利用200m空间完成建站?
兔展官网 在线制作,怎样制作微信请帖?
如何在香港服务器上快速搭建免备案网站?
长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?
建站之星免费版是否永久可用?
建站三合一如何选?哪家性价比更高?
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
,如何利用word制作宣传手册?
如何制作算命网站,怎么注册算命网站?
seo网站制作优化,网站SEO优化步骤有哪些?
招商网站制作流程,网站招商广告语?
如何快速配置高效服务器建站软件?
建站之星代理商如何保障技术支持与售后服务?
c# 在高并发场景下,委托和接口调用的性能对比
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
如何通过智能用户系统一键生成高效建站方案?
威客平台建站流程解析:高效搭建教程与设计优化方案
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
建站主机选哪家性价比最高?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
如何在腾讯云服务器快速搭建个人网站?
如何快速搭建支持数据库操作的智能建站平台?
建站主机核心功能解析:服务器选择与网站搭建流程指南
SQL查询语句优化的实用方法总结
如何自定义建站之星网站的导航菜单样式?
如何用虚拟主机快速搭建网站?详细步骤解析
*服务器网站为何频现安全漏洞?
如何注册花生壳免费域名并搭建个人网站?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
如何通过云梦建站系统实现SEO快速优化?
建站主机数据库如何配置才能提升网站性能?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
*请认真填写需求信息,我们会在24小时内与您取得联系。