基于javascript实现放大镜特效


Posted in Javascript onDecember 03, 2020

本文实例为大家分享了javascript实现放大镜特效的具体代码,供大家参考,具体内容如下

我们在逛pc端商城时,鼠标放到商品上经常会看到一个类似放大镜效果的蒙层,

<!DOCTYPE html>
<html>

<head>
 <meta charset="UTF-8">
 <title></title>
 <style type="text/css">
  * {
   margin: 0px;
   padding: 0px;
  }
  
  #min {
   width: 350px;
   height: 350px;
   border: 1px solid #ccc;
   position: absolute;
   left: 50px;
   top: 50px;
  }
  
  #min img {
   width: 350px;
   height: 350px;
  }
  
  #max {
   width: 500px;
   height: 500px;
   position: absolute;
   left: 500px;
   top: 50px;
   border: 1px solid #ccc;
   overflow: hidden;
   display: none;
  }
  
  #max img {
   position: absolute;
   left: 0;
   top: 0;
  }
  
  #mask {
   width: 200px;
   height: 200px;
   background: rgba(255, 0, 0, 0.5);
   position: absolute;
   left: 0px;
   top: 0px;
   cursor: pointer;
   display: none;
  }
 </style>
</head>

<body>
 <div id="min">
  <img src="img/min.jpg" alt="" />
  <div id="mask"></div>
 </div>
 <div id="max">
  <img src="img/max.jpg" id="maxImg" />
 </div>
 <script type="text/javascript">
  // 1.鼠标经过小盒子,遮罩层出现,大盒子出现
  // 2.遮罩层跟随鼠标移动
  // 3.遮罩层移动,大盒子里的图片反方向移动
  var oMin = document.getElementById('min');
  var oMax = document.getElementById('max');
  var oMask = document.getElementById('mask');
  var oMaxImg = document.getElementById('maxImg');
  oMin.onmousemove = function(e) {
   // 1.鼠标经过小盒子,遮罩层和大盒子出现
   oMask.style.display = 'block';
   oMax.style.display = 'block';
   // 2.拿到鼠标在小盒子上的坐标
   var minX = e.clientX - oMin.offsetLeft;
   var minY = e.clientY - oMin.offsetTop;
   // 3.将鼠标放置在遮罩层的中间
   minX = minX - oMask.offsetWidth / 2;
   minY = minY - oMask.offsetHeight / 2;
   // 4.遮罩层可以移动的最大距离
   var maxWidth = oMin.offsetWidth - oMask.offsetWidth;
   var maxHeight = oMin.offsetHeight - oMask.offsetHeight;
   // 限定遮罩层的位置
   if (minX > maxWidth) {
    minX = maxWidth;
   } else if (minX <= 0) {
    minX = 0;
   }
   if (minY > maxHeight) {
    minY = maxHeight;
   } else if (minY <= 0) {
    minY = 0;
   }
   // 设定遮罩层的偏移
   oMask.style.left = minX + 'px';
   oMask.style.top = minY + 'px';
   // 大图片移动的距离=遮罩层移动的距离/遮罩层可以移动的最大距离*大图片最大移动距离
   var ratioX = minX / maxWidth;
   var ratioY = minY / maxHeight;
   // 计算出大图片的移动距离
   oMaxImg.style.left = -ratioX * (oMaxImg.offsetWidth - oMax.offsetWidth) + 'px';
   oMaxImg.style.top = -ratioY * (oMaxImg.offsetHeight - oMax.offsetHeight) + 'px';
  };
  // 鼠标移开,遮罩层和大盒子消失
  oMin.onmouseout = function() {
   oMask.style.display = 'none';
   oMax.style.display = 'none';
  }
 </script>
</body>

</html>

效果图:

基于javascript实现放大镜特效

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
iframe自适应宽度、高度 ie6 7 8,firefox 3.86下测试通过
Jul 29 Javascript
JQUBAR1.1 jQuery 柱状图插件发布
Nov 28 Javascript
JavaScript实现表格点击排序的方法
May 11 Javascript
jquery判断iPhone、Android设备类型
Sep 14 Javascript
Vue.js 和 MVVM 的注意事项
Nov 07 Javascript
JavaScript数据结构中串的表示与应用实例
Apr 12 Javascript
JavaScript设计模式之代理模式详解
Jun 09 Javascript
bootstrap datetimepicker控件位置异常的解决方法
Nov 23 Javascript
微信小程序实现收藏与取消收藏切换图片功能
Aug 03 Javascript
Element-ui之ElScrollBar组件滚动条的使用方法
Sep 14 Javascript
es6基础学习之解构赋值
Dec 10 Javascript
JavaScript构造函数原理及实现流程解析
Nov 19 Javascript
javascript实现时钟动画
Dec 03 #Javascript
javascript中导出与导入实现模块化管理教程
Dec 03 #Javascript
JS如何实现在弹出窗口中加载页面
Dec 03 #Javascript
对vue生命周期的深入理解
Dec 03 #Vue.js
在实例中重学JavaScript事件循环
Dec 03 #Javascript
js 数据类型判断的方法
Dec 03 #Javascript
用vue设计一个日历表
Dec 03 #Vue.js
You might like
德劲1103二次变频版的打磨
2021/03/02 无线电
PHP获取MSN好友列表类的实现代码
2013/06/23 PHP
php缓冲 output_buffering和ob_start使用介绍
2014/01/30 PHP
取得单条网站评论以数组形式进行输出
2014/07/28 PHP
Laravel 微信小程序后端实现用户登录的示例代码
2019/11/26 PHP
轻轻松松学习JavaScript
2007/02/25 Javascript
[HTML/CSS/Javascript]WWTJS
2007/09/25 Javascript
sencha ext js 6 快速入门(必看)
2016/06/01 Javascript
Javascript中call,apply,bind方法的详解与总结
2016/12/12 Javascript
bootstrap实现每隔5秒自动轮播效果
2016/12/20 Javascript
JavaScript队列的应用实例详解【经典数据结构】
2017/04/12 Javascript
knockoutjs模板实现树形结构列表
2017/07/31 Javascript
详解angularjs 学习之 scope作用域
2018/01/15 Javascript
echarts大屏字体自适应的方法步骤
2019/07/12 Javascript
浅谈Three.js截图并下载的大坑
2019/11/01 Javascript
vue实现计算器功能
2020/02/22 Javascript
Vue + Node.js + MongoDB图片上传组件实现图片预览和删除功能详解
2020/04/29 Javascript
[47:04]EG vs RNG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/18 DOTA
python实现简单socket程序在两台电脑之间传输消息的方法
2015/03/13 Python
Python读csv文件去掉一列后再写入新的文件实例
2017/12/28 Python
Python http接口自动化测试框架实现方法示例
2018/12/06 Python
Python单元测试unittest的具体使用示例
2018/12/17 Python
WxPython建立批量录入框窗口
2019/02/27 Python
python实现最小二乘法线性拟合
2019/07/19 Python
HTML5 Canvas 绘图——使用 Canvas 绘制图形图文教程 使用html5 canvas 绘制精美的图
2015/08/31 HTML / CSS
The North Face北面荷兰官网:美国著名户外品牌
2019/10/16 全球购物
*p++ 自增p 还是p所指向的变量
2016/07/16 面试题
客服端调用EJB对象的几个基本步骤
2012/01/15 面试题
学前教育教师求职自荐信
2013/09/22 职场文书
感恩节活动策划方案
2014/05/16 职场文书
小学国庆节活动方案策划书
2014/09/16 职场文书
授权委托书怎么写
2014/09/25 职场文书
勤俭节约倡议书范文
2015/04/29 职场文书
2015年音乐教研组工作总结
2015/07/22 职场文书
Nginx tp3.2.3 404问题解决方案
2021/03/31 Servers
SpringBoot2零基础到精通之数据库专项精讲
2022/03/22 Java/Android