基于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 相关文章推荐
jquery左右全屏大尺寸多图滑动效果代码分享
Aug 28 Javascript
浅析JavaScript的几种Math函数,random(),ceil(),round(),floor()
Dec 22 Javascript
AngularJS实现表单验证功能
Jan 09 Javascript
JavaScript如何获取到导航条中HTTP信息
Oct 10 Javascript
vue组件父子间通信之综合练习(聊天室)
Nov 07 Javascript
JS实现简易换图时钟功能分析
Jan 04 Javascript
Angular4学习教程之HTML属性绑定的方法
Jan 04 Javascript
nginx+vue.js实现前后端分离的示例代码
Feb 12 Javascript
微信小程序实现人脸识别
May 25 Javascript
记一次webapck4 配置文件无效的解决历程
Sep 19 Javascript
微信小程序 WXML节点信息查询详解
Jul 29 Javascript
原生js实现自定义难度的扫雷游戏
Jan 22 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
ADODB的数据库封包程序库
2006/12/31 PHP
php 批量生成html,txt文件的实现代码
2013/06/26 PHP
使用 PHPStorm 开发 Laravel
2015/03/24 PHP
PHP递归获取目录内所有文件的实现方法
2016/11/01 PHP
CentOS7编译安装php7.1的教程详解
2019/04/18 PHP
简单JS代码压缩器
2006/10/12 Javascript
javascript 函数式编程
2007/08/16 Javascript
30个让人兴奋的视差滚动(Parallax Scrolling)效果网站
2012/03/04 Javascript
jquery使用$(element).is()来判断获取的tagName
2014/08/24 Javascript
jQuery随机密码生成的方法
2015/03/09 Javascript
Jquery EasyUI实现treegrid上显示checkbox并取选定值的方法
2016/04/29 Javascript
用原生JS对AJAX做简单封装的实例代码
2016/07/13 Javascript
微信小程序 中wx.chooseAddress(OBJECT)实例详解
2017/03/31 Javascript
详解VueJS应用中管理用户权限
2018/02/02 Javascript
JavaScript设计模式之代理模式实例分析
2019/01/16 Javascript
javascript json字符串到json对象转义问题
2019/01/22 Javascript
jQuery分组选择器简单用法示例
2019/04/04 jQuery
ECharts地图绘制和钻取简易接口详解
2019/07/12 Javascript
js瀑布流布局的实现
2020/06/28 Javascript
[04:22]DSPL第二期精彩集锦:残血反杀!
2014/12/10 DOTA
Python自动化测试Eclipse+Pydev 搭建开发环境
2016/08/15 Python
Pycharm如何打断点的方法步骤
2019/06/13 Python
python应用Axes3D绘图(批量梯度下降算法)
2020/03/25 Python
用HTML5制作一个简单的桌球游戏的教程
2015/05/12 HTML / CSS
Hertz荷兰:荷兰和全球租车
2018/01/07 全球购物
分解成质因数(如435234=251*17*17*3*2,据说是华为笔试题)
2014/07/16 面试题
C语言笔试题回忆
2015/04/02 面试题
关于期中考试的反思
2014/02/02 职场文书
社区优秀志愿者先进事迹
2014/05/09 职场文书
2014年商场国庆节活动策划方案
2014/09/16 职场文书
2014年安全员工作总结
2014/11/13 职场文书
2016应届毕业生实习心得体会
2015/10/09 职场文书
2015年度工程师评职称工作总结
2015/10/14 职场文书
信息技术课教学反思
2016/02/23 职场文书
教你使用Pandas直接核算Excel中快递费用
2021/05/12 Python
CI Games宣布《堕落之王2》使用虚幻引擎5制作 预计将于2023年正式发售
2022/04/11 其他游戏