用js实现放大镜效果


Posted in Javascript onOctober 28, 2020

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

该放大区域用背景图片放大

<!DOCTYPE html>
<html lang="zh">
 <head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title></title>
 <style type="text/css">
 body {
 height: 1200px;
 background-color: lightskyblue;
 }

 ul {
 margin: 0;
 padding: 0;
 list-style: none;
 }

 .itemarea {
 position: relative;
 width: 500px;
 height: 680px;
 border: 1px black solid;
 margin: 50px auto;
 }

 .itemarea .pic {
 margin-bottom: 15px;
 }

 .itemarea img {
 width: 500px;
 height: 600px;

 }

 .itemarea .pic .cover {
 position: absolute;
 left: 0;
 top: 0;
 width: 200px;
 height: 200px;
 background-image: url(img/7.png);
 opacity: 0.6;
 display: none;
 }

 .itemarea .list {
 display: flex;

 }

 .itemarea .list li {
 margin: auto;
 }

 .itemarea .list img {
 display: block;
 width: 50px;
 height: 50px;
 }

 .itemarea .detail {
 position: absolute;
 top: 0;
 left: 500px;
 /* 此处为放大2倍,显示框的大小是遮阴框宽高的2倍 */
 width: 400px;
 height: 400px;
 display: none;
 border: 1px black solid;
 background: url(img/1.PNG);
 /* 此处放大2倍,背景图片的宽高是左边显示图片的2倍 */
 background-size: 1000px 1200px;
 /* background-size: 200%; 或者这样写*/

 }

 .itemarea .list .current {
 border: 2px green solid;
 }
 </style>
 </head>
 <body>
 <div class="itemarea">
 <div class="pic">
 <img src="img/1.PNG">
 <div class="cover"></div>
 </div>
 <ul class="list">
 <li><img src="img/1.PNG"></li>
 <li><img src="img/2.PNG"></li>
 <li><img src="img/3.PNG"></li>
 <li><img src="img/4.PNG"></li>
 <li><img src="img/5.PNG"></li>
 <li><img src="img/6.PNG"></li>
 </ul>
 <div class="detail">

 </div>
 </div>
 <script type="text/javascript">
 /* 
 需求
 1,鼠标放入图片时候,会动态修改图片地址
 2,鼠标放入大图,会动态修改右边图片位置
 2.1显示图片的放大镜,
 2.2显示右边效果
 */
 var itemarea = document.querySelector(".itemarea");
 var list = document.querySelector(".list");
 /* 上面的大图片 */
 img = document.querySelector(".pic img");
 /* 所有的图片 */
 imgs = list.querySelectorAll("img");
 /* 主图片展示区域 */
 pic = document.querySelector(".itemarea .pic");
 /* 放大镜 */
 cover = document.querySelector(".cover");
 /* 放大的区域 */
 detail = document.querySelector(".detail");
 /* 监听事件,切换图片src */
 list.addEventListener("mousemove", function(e) {
 if (e.target.tagName == "IMG") {
  img.src = e.target.src;
  detail.style.backgroundImage = "url(" + e.target.src + ")";
  /* 遍历 所有边框都为空*/
  imgs.forEach(function(item) {
  item.className = "";
  })
  /* 选中的改变边框颜色*/
  e.target.className = "current";
 }
 })
 pic.addEventListener("mousemove", function(e) {
 /* 放大镜距离浏览器的距离 */
 var x = e.clientX;
 y = e.clientY;
 /* 图片框距离浏览器的距离 */
 cx = pic.getBoundingClientRect().left;
 cy = pic.getBoundingClientRect().top;
 tx = x - cx - 100;
 ty = y - cy - 100;
 if (tx < 0) {
  tx = 0;
 }
 if (ty < 0) {
  ty = 0;
 }
 /* 显示图片宽-遮阴框的宽 */
 if (tx >300) {
  tx = 300;
 }
 /* 显示图片高-遮阴框的高 */
 if (ty > 400) {
  ty = 400;
 }
 cover.style.left = tx + "px";
 cover.style.top = ty + "px";
 /* 根据遮阴框在盒子的移动距离百分比------对应放映框在大图片的移动距离百分比 */
 /* tx,ty/遮阴框的极限范围 */
 detail.style.backgroundPosition = tx / 300 * 100 + "%" + ty / 400 * 100 + "%";
 })
 /* 移除隐藏 */
 itemarea.onmouseout = function() {
 cover.style.display = "none";
 detail.style.display = "none"
 }
 itemarea.onmouseover = function() {
 cover.style.display = "block";
 detail.style.display = "block";
 }
 </script>
 </body>
</html>

效果如下:

用js实现放大镜效果

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

Javascript 相关文章推荐
js 多种变量定义(对象直接量,数组直接量和函数直接量)
May 24 Javascript
IFrame跨域高度自适应实现代码
Aug 16 Javascript
js全选按钮的实现方法
Nov 17 Javascript
自动化测试读写64位操作系统的注册表
Aug 15 Javascript
JS实现新建文件夹功能
Jun 17 Javascript
简单快速的实现js计算器功能
Aug 17 Javascript
深入理解vue中slot与slot-scope的具体使用
Jan 26 Javascript
JS实现换肤功能的方法实例详解
Jan 30 Javascript
laypage.js分页插件使用方法详解
Jul 27 Javascript
基于Vue el-autocomplete 实现类似百度搜索框功能
Oct 25 Javascript
JavaScript This指向问题详解
Nov 25 Javascript
针对Vue路由history模式下Nginx后台配置操作
Oct 22 Javascript
如何在 ant 的table中实现图片的渲染操作
Oct 28 #Javascript
WebStorm中如何将自己的代码上传到github示例详解
Oct 28 #Javascript
原生JS生成指定位数的验证码
Oct 28 #Javascript
微信小程序接入vant Weapp组件的详细步骤
Oct 28 #Javascript
Ant-design-vue Table组件customRow属性的使用说明
Oct 28 #Javascript
通过JS判断网页是否为手机打开
Oct 28 #Javascript
ant design vue嵌套表格及表格内部编辑的用法说明
Oct 28 #Javascript
You might like
SONY ICF-SW07收音机电路分析
2021/03/02 无线电
用PHP程序实现支持页面后退的两种方法
2008/06/30 PHP
分享一段PHP制作的中文拼音首字母工具类
2014/12/11 PHP
php中magic_quotes_gpc对unserialize的影响分析
2014/12/16 PHP
PHP+iframe图片上传实现即时刷新效果
2016/11/18 PHP
php微信扫码支付 php公众号支付
2019/03/24 PHP
汉化英文版的Dreamweaver CS5并自动提示jquery
2010/11/25 Javascript
鼠标右击事件代码(asp.net后台)
2011/01/27 Javascript
事件绑定之小测试  onclick &amp;&amp; addEventListener
2011/07/31 Javascript
JavaScript代码简单实现求杨辉三角给定行的最大值
2013/10/29 Javascript
创建你的第一个AngularJS应用的方法
2015/06/16 Javascript
javascript实现base64 md5 sha1 密码加密
2015/09/09 Javascript
node.js使用cluster实现多进程
2016/03/17 Javascript
jQuery unbind 删除绑定事件详解
2016/05/24 Javascript
详解JavaScript跨域总结与解决办法
2016/10/31 Javascript
yarn的使用与升级Node.js的方法详解
2017/06/04 Javascript
jQuery实现弹窗下底部页面禁止滑动效果
2017/12/19 jQuery
详解如何优雅地在React项目中使用Redux
2017/12/28 Javascript
vue实例中data使用return包裹的方法
2018/08/27 Javascript
vue中使用codemirror的实例详解
2018/11/01 Javascript
详解koa2学习中使用 async 、await、promise解决异步的问题
2018/11/13 Javascript
详解js location.href和window.open的几种用法和区别
2019/12/02 Javascript
vue-router之解决addRoutes使用遇到的坑
2020/07/19 Javascript
Django结合ajax进行页面实时更新的例子
2019/08/12 Python
pytorch 在网络中添加可训练参数,修改预训练权重文件的方法
2019/08/17 Python
python 使用shutil复制图片的例子
2019/12/13 Python
Python GUI自动化实现绕过验证码登录
2020/01/10 Python
python正则过滤字母、中文、数字及特殊字符方法详解
2020/02/11 Python
tensorflow 获取checkpoint中的变量列表实例
2020/02/11 Python
Python requests模块安装及使用教程图解
2020/06/30 Python
浅析几个CSS3常用功能的写法
2014/06/05 HTML / CSS
FILA斐乐中国官方商城:意大利运动品牌
2017/01/25 全球购物
求高于平均分的学生学号及成绩
2016/09/01 面试题
了解AppleShare protocol(AppleShare协议)吗
2015/08/28 面试题
六一活动主持词
2015/06/30 职场文书
乡镇司法所2015年度工作总结
2015/10/14 职场文书