基于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 相关文章推荐
Javascript(AJAX)解析XML的代码(兼容FIREFOX/IE)
Jul 11 Javascript
firefox下input type=&quot;file&quot;的size是多大
Oct 24 Javascript
Knockout visible绑定使用方法
Nov 15 Javascript
利用了jquery的ajax实现二级联互动菜单
Dec 02 Javascript
jquery对象和javascript对象即DOM对象相互转换
Aug 07 Javascript
JS使用正则截取两个字符串之间的字符串实现方法详解
Jan 06 Javascript
ES6解构赋值的功能与用途实例分析
Oct 31 Javascript
Vue-Quill-Editor富文本编辑器的使用教程
Sep 21 Javascript
Vue基于vuex、axios拦截器实现loading效果及axios的安装配置
Apr 26 Javascript
小程序实现投票进度条
Nov 20 Javascript
Vue Router 实现动态路由和常见问题及解决方法
Mar 06 Javascript
如何利用vue实现波谱拟合详解
Nov 05 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
如何使用php输出时间格式
2013/08/31 PHP
php脚本运行时的超时机制详解
2016/02/17 PHP
简单介绍PHP非阻塞模式
2016/03/03 PHP
ThinkPHP中类的构造函数_construct()与_initialize()的区别详解
2017/03/13 PHP
php和vue配合使用技巧和方法
2019/05/09 PHP
js 优化次数过多的循环 考虑到性能问题
2011/03/05 Javascript
JavaScript入门之事件、cookie、定时等
2011/10/21 Javascript
IE与Firefox在JavaScript上的7个不同句法分享
2011/10/30 Javascript
Jquery事件的连接使用示例
2013/06/18 Javascript
JS检测图片大小的实例
2013/08/21 Javascript
javascript获取dom的下一个节点方法
2014/09/05 Javascript
js获取浏览器基本信息大全
2014/11/27 Javascript
jQuery插件Timelinr 实现时间轴特效
2015/10/04 Javascript
jquery设置表单元素为不可用的简单代码
2016/07/04 Javascript
bootstrap 设置checkbox部分选中效果
2017/04/20 Javascript
浅谈react受控组件与非受控组件(小结)
2018/02/09 Javascript
vue移动端UI框架实现QQ侧边菜单组件
2018/03/09 Javascript
浅析vue-router中params和query的区别
2019/12/24 Javascript
Node.js API详解之 vm模块用法实例分析
2020/05/27 Javascript
谈谈node.js中的模块系统
2020/09/01 Javascript
vue基于Echarts的拖拽数据可视化功能实现
2020/12/04 Vue.js
零基础写python爬虫之打包生成exe文件
2014/11/06 Python
在RedHat系Linux上部署Python的Celery框架的教程
2015/04/07 Python
详解JavaScript编程中的window与window.screen对象
2015/10/26 Python
python如何在列表、字典中筛选数据
2018/03/19 Python
Python中GeoJson和bokeh-1的使用讲解
2019/01/03 Python
python 实现将小图片放到另一个较大的白色或黑色背景图片中
2019/12/12 Python
解决pip install psycopg2出错问题
2020/07/09 Python
Spy++的使用方法及下载教程
2021/01/29 Python
HTML5中的Article和Section元素认识及使用
2013/03/22 HTML / CSS
Collection和Collections的区别
2016/05/02 面试题
Servlet如何得到客户端机器的信息
2014/10/17 面试题
工业设计专业推荐信
2013/10/29 职场文书
保研推荐信格式
2015/03/25 职场文书
2015初中生物教研组工作总结
2015/07/21 职场文书
2016年校园社会综合治理宣传月活动总结
2016/03/16 职场文书