Web开发 —— 放大镜效果(HTML、CSS、JavaScript)

目录

一、需求描述

二、实现效果

三、完整代码

四、实现过程

1、HTML 页面结构

2、CSS 元素样式

3、JavaScript动态控制

(1)获取元素

(2)控制大图和遮罩层的显隐性

(3)遮罩层跟随鼠标移动

(4)控制遮罩层移动范围

(5)显示放大图


一、需求描述

前端实现放大镜效果;

  • 鼠标移入图片区域,显示遮罩层;
  • 鼠标移出图片区域,隐藏遮罩层;
  • 鼠标移动,遮罩层跟随鼠标移动;
  • 遮罩层不能超出图片所在区域;
  • 遮罩层覆盖的图片区域按照指定比例放大显示;
  • 遮罩层移动,放大图跟随移动;

二、实现效果

初始效果

放大效果

三、完整代码

【test.html】

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>放大镜效果</title><style>* {margin: 0;padding: 0;}.one-img-box,.big-img-box {position: relative;width: 300px;height: 300px;box-shadow: 0 0 6px 1px #cacaca;border-radius: 10px;overflow: hidden;}.one-img-box {display: inline-block;top: 60px;left: 60px;cursor: move;}.one-img-box>img {width: 100%;height: 100%;}.big-img-box {/* display: inline-block; */display: none;top: 60px;left: 100px;}.big-img-box>img {width: 300%;height: 300%;}.big-img {position: absolute;left: 0;top: 0;}.mask {/* display: inline-block; */display: none;position: absolute;left: 0;top: 0;width: 100px;height: 100px;background-color: yellowgreen;opacity: .4;}</style>
</head><body><div class="one-img-box"><img src="D:\test\girl.png" alt=""><div class="mask"></div></div><div class="big-img-box"><img class="big-img" src="D:\test\girl.png" alt=""></div>
</body>
<script>// 1、获取元素// 获取原图的盒子var oneImgBox = document.querySelector('.one-img-box');// 获取遮罩层var mask = document.querySelector('.mask');// 获取大图盒子var bigImgBox = document.querySelector('.big-img-box');// 获取大图var bigImg = document.querySelector('.big-img');// 2、控制显示与隐藏// 2.1 鼠标经过 oneImgBox,显示 mask遮挡层 和 bigImgBox大盒子;oneImgBox.addEventListener('mouseover', function () {mask.style.display = 'inline-block';bigImgBox.style.display = 'inline-block';})// 2.2 鼠标移出 oneImgBox,隐藏 mask遮挡层 和 bigImgBox大盒子;oneImgBox.addEventListener('mouseout', function () {mask.style.display = 'none';bigImgBox.style.display = 'none';})// 3、遮罩层跟随鼠标移动oneImgBox.addEventListener('mousemove', function (e) {// 3.1 计算鼠标在盒子内的坐标var mouseX = e.pageX - oneImgBox.offsetLeft;var mouseY = e.pageY - oneImgBox.offsetTop;// 3.2 计算遮罩层的移动位置// 移动位置 = 鼠标的移动距离 - 遮罩层自己宽度\高度的一半(鼠标会在遮罩层中心位置,否则在左上角)var maskX = mouseX - mask.offsetWidth / 2;var maskY = mouseY - mask.offsetWidth / 2;// 计算结果赋给遮罩层;// mask.style.left = maskX + 'px';// mask.style.top = maskY + 'px';// 4、控制遮罩层的移动范围// 4.1 计算遮罩层最大移动宽度\高度 = 原图盒子的宽度\高度 - 遮罩层的宽度\高度var maskMaxX = oneImgBox.offsetWidth - mask.offsetWidth;var maskMaxY = oneImgBox.offsetHeight - mask.offsetHeight// 如果移动距离 大于 最大移动距离,则取最大的移动距离// 如果移动距离 小于 0,则取0;maskX = maskX > maskMaxX ? maskMaxX : maskX < 0 ? 0 : maskX;maskY = maskY > maskMaxY ? maskMaxY : maskY < 0 ? 0 : maskY;// 计算结果赋给遮罩层mask.style.left = maskX + 'px';mask.style.top = maskY + 'px';// 5、按比例显示大图// 5.1 放大比例 = 原图的宽度 / 大图的宽度 = 1 / 3var rate = oneImgBox.offsetLeft / bigImg.offsetWidth;// 5.2 大图的移动距离 = 遮罩层的移动距离 * 放大比例 (注意大图的移动方向与遮罩层相反)bigImg.style.left = - maskX * 3 + 'px';bigImg.style.top = - maskY * 3 + 'px';})
</script></html>

四、实现过程

1、HTML 页面结构

一个原图片的盒子【div元素】,里面放原图【img元素】和遮罩层【div元素】

一个放大后的图片盒子【div元素】,里面放大图【img元素】;

<body><div class="one-img-box"><img src="D:\test\girl.png" alt=""><div class="mask"></div></div><div class="big-img-box"><img class="big-img" src="D:\test\girl.png" alt=""></div>
</body>

2、CSS 元素样式

(1)两个盒子及图片样式

这里设置原图的宽高均为300px;大图的宽高是原图的三倍;

【 cursor: move; 】使得鼠标在移入图片变成“移动”样式;

【overflow: hidden;】使得图片超出盒子部分被隐藏(大图);

注意,大图盒子最初的的display的值应设为none,显隐性由鼠标移入或移出图片决定;

.one-img-box,
.big-img-box {position: relative;width: 300px;height: 300px;box-shadow: 0 0 6px 1px #cacaca;border-radius: 10px;overflow: hidden;
}.one-img-box {display: inline-block;top: 60px;left: 60px;cursor: move;
}.one-img-box>img {width: 100%;height: 100%;
}.big-img-box {display: inline-block;top: 60px;left: 100px;
}.big-img-box>img {width: 300%;height: 300%;
}.big-img {position: absolute;left: 0;top: 0;
}

(2)遮罩层样式

遮罩层使用绝对定位,根据鼠标的移动位置,再更改其left和top值,使遮罩层跟随鼠标移动;

注意:遮罩层最初不显示,display的值也应设为none;

.mask {display: inline-block;position: absolute;left: 0;top: 0;width: 100px;height: 100px;background-color: yellowgreen;opacity: .4;
}

注意:

原图的宽高均为300px;遮罩层的宽高均为100px;遮罩层与原图的宽高比例都是1 :3;

放大图的盒子和大图的比例需要一致(1 :3),所以大图的宽高应该均为900px;

这里的比例如果不一致,则会出现,遮罩层覆盖的内容,在大图中没有完全显示,或显示不全;当然可以自定义这个比例;

3、JavaScript动态控制

(1)获取页面元素

将页面中需要操作的元素都进行获取;

这里使用的是querySelector()方法来获取元素,是JavaScript中获取dom元素的方式之一;

<script>// 1、获取元素// 获取原图的盒子var oneImgBox = document.querySelector('.one-img-box');// 获取遮罩层var mask = document.querySelector('.mask');// 获取大图盒子var bigImgBox = document.querySelector('.big-img-box');// 获取大图var bigImg = document.querySelector('.big-img');......
</script>

(2)控制大图和遮罩层的显隐性

先设置大图盒子和遮罩层的display 为 none;

......
.big-img-box {/* display: inline-block; */display: none;......
}
.mask {/* display: inline-block; */display: none;......
}
......

分析需求可知:

  • 遮罩层和大图盒子的显示与隐藏是同时的,大图盒子显示则遮罩层显示,大图盒子隐藏则遮罩层隐藏;
  • 当鼠标经过原图时,两者显示,需要给这个原图盒子注册鼠标经过事件,完成相应功能;
  • 当鼠标移出原图时,两者隐藏,也需要给这个原图盒子注册鼠标移出事件,完成相应功能;
<script>......// 2、控制显示与隐藏// 2.1 鼠标经过 oneImgBox,显示 mask遮挡层 和 bigImgBox大盒子;oneImgBox.addEventListener('mouseover', function () {mask.style.display = 'inline-block';bigImgBox.style.display = 'inline-block';})// 2.2 鼠标移出 oneImgBox,隐藏 mask遮挡层 和 bigImgBox大盒子;oneImgBox.addEventListener('mouseout', function () {mask.style.display = 'none';bigImgBox.style.display = 'none';})......
</script>

(3)遮罩层跟随鼠标移动

分析需求可知:

  • 遮罩层在盒子内的移动距离,实际就是鼠标的移动距离(遮罩层跟着鼠标移动),但注意这个是遮罩层左上角的位置;
  • 遮罩层中心的移动距离,要在鼠标移动距离的基础上,减去遮罩层自身的宽度或高度;
  • 鼠标的移动距离mouseX\mouseY为,鼠标在页面中的X坐标\Y坐标 - 图片盒子的左\上边距;
  • 注意,这里鼠标一开始进入图片盒子就开始计算;
<script>......// 3、遮罩层跟随鼠标移动oneImgBox.addEventListener('mousemove', function (e) {// 3.1 计算鼠标在盒子内的坐标var mouseX = e.pageX - oneImgBox.offsetLeft;var mouseY = e.pageY - oneImgBox.offsetTop;// 3.2 计算遮罩层的移动位置// 移动位置 = 鼠标的移动距离 - 遮罩层自己宽度\高度的一半(鼠标会在遮罩层中心位置,否则在左上角)var maskX = mouseX - mask.offsetWidth / 2;var maskY = mouseY - mask.offsetWidth / 2;// 计算结果赋给遮罩层;mask.style.left = maskX + 'px';mask.style.top = maskY + 'px';......})
</script>

注意:

这里存在一个问题,就是当鼠标靠近图片边缘的时候,遮罩层会继续移动,被裁剪;

应该加以判断,控制遮罩层的移动范围,使得遮罩层不会被移出去;

(4)控制遮罩层移动范围

分析需求可知:

  • 遮罩层的移动距离不能小于 0,也不能超过它的最大移动距离;
  • 遮罩层最大移动宽度\高度 = 原图盒子的宽度\高度 - 遮罩层的宽度\高度;
  • 如果移动距离 大于 最大移动距离,则取最大的移动距离;
  • 如果移动距离 小于 0,则取0;
<script>......// 3、遮罩层跟随鼠标移动oneImgBox.addEventListener('mousemove', function (e) {......// 4、控制遮罩层的移动范围// 4.1 计算遮罩层最大移动宽度\高度 = 原图盒子的宽度\高度 - 遮罩层的宽度\高度var maskMaxX = oneImgBox.offsetWidth - mask.offsetWidth;var maskMaxY = oneImgBox.offsetHeight - mask.offsetHeight// 如果移动距离 大于 最大移动距离,则取最大的移动距离// 如果移动距离 小于 0,则取0;maskX = maskX > maskMaxX ? maskMaxX : maskX < 0 ? 0 : maskX;maskY = maskY > maskMaxY ? maskMaxY : maskY < 0 ? 0 : maskY;// 计算结果赋给遮罩层mask.style.left = maskX + 'px';mask.style.top = maskY + 'px';......})
</script>

(5)按比例移动放大图

分析需求可知:

  • 放大比例 = 原图的宽度 / 大图的宽度;
  • 大图的移动距离 = 遮罩层的移动距离 * 放大比例;
  • 注意:大图的移动方向与遮罩层相反;
<script>......// 3、遮罩层跟随鼠标移动oneImgBox.addEventListener('mousemove', function (e) {......// 5、按比例显示大图// 5.1 放大比例 = 原图的宽度 / 大图的宽度 = 1 / 3var rate = oneImgBox.offsetLeft / bigImg.offsetWidth;// 5.2 大图的移动距离 = 遮罩层的移动距离 * 放大比例 (注意大图的移动方向与遮罩层相反)bigImg.style.left = - maskX * 3 + 'px';bigImg.style.top = - maskY * 3 + 'px';})
</script>

=========================================================================

每天进步一点点~!

记录一下这个实用的前端"小轮子"~! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/45571.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

k8s核心操作_k8s中的存储抽象_基本概念与NFS搭建_Deployment使用NFS进行挂载---分布式云原生部署架构搭建028

然后我们继续开始看 如果我们使用容器部署,比如我们有三个节点,一个是master,一个node1 一个是node2 那么pod 中我们可以看到,容器中的 /data 等各个目录都映射了出来了,但是 如果比如上面红色的部分,有个pod,原来在node2上,最右边那个,但是这个pod宕机了 那么,k8s会在node…

永磁同步电机谐波抑制算法(7)——基于自适应陷波(adaptive notch filter,ANF)的精确谐波电流抑制策略

1.前言 1.1经典谐波抑制策略存在的问题 在之前的谐波抑制专题中&#xff0c;主要介绍了两种谐波抑制策略——基于多同步旋转坐标系的谐波抑制策略以及基于比例积分谐振PIR调节器的谐波抑制策略&#xff0c;同时还介绍了这两种策略的改进办法&#xff0c;进而使得这两种策略在…

Go:基本变量与数据类型

目录 前言 前期准备 Hello World! 一、基本变量 1.1 声明变量 1.2 初始化变量 1.3 变量声明到初始化的过程 1.4 变量值交换 1.5 匿名变量 1.6 变量的作用域 二、数据类型 1.1 整型 1.2 浮点型 1.3 字符串 1.4 布尔类型 1.5 数据类型判断 1.6 数据类型转换 1.…

NewStarCTF 2023 week5--web

目录 Unserialize Again 法一:(非预期) 法二: Final Yes Pickle pppython? 4-复盘 Unserialize Again f12告诉了我们cookie, 查看一下,可以发现 pairing.php <?php highlight_file(__FILE__); error_reporting(0); class story{private $useradmin;public $p…

Centos7 新增yum源

背景&#xff1a;原来的yum源&#xff0c;无法下载yum包了。新增一个阿里云的&#xff08;网易163的源失效了&#xff0c;无法使用&#xff09; Could not retrieve mirrorlist http://mirrorlist.centos.org/?release7&archx86_64&repoos&infrastock error was …

three.js官方案例webgpu_reflection.html学习记录

目录 ​1 判断浏览器是否支持 2 THREE.DirectionalLight 2.1DirectionalLightShadow 3 Texture 3.1 .wrapS 3.2 .wrapT 3.3 .colorSpace 4 创建地面 5 WebGPURenderer 6 OrbitControls 控制器 7 屏幕后处理 import * as THREE from three;import { MeshPhongNodeMa…

简析“请求头”——可以用“头部字典”按需定制请求头

请求头是HTTP请求的重要部分&#xff0c;可以用“头部字典”按需定制请求头。 (笔记模板由python脚本于2024年07月12日 19:28:44创建&#xff0c;本篇笔记适合喜欢钻研web知识点的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free…

RSA算法(C++)

RSA加解密过程 RSA为非对称加密算法&#xff0c;由一对公钥和一对私钥构成&#xff0c;私钥加密公钥解密&#xff0c;公钥加密私钥解密 如下图,D为私密的&#xff0c;假设传输英文字母&#xff0c;我们给英文字母编号A1,B2,C3… RSA加解密过程 两对密钥产生方法如下 C Op…

【RHCE】基于密钥的身份验证(Win-Linux)

目的&#xff1a;要提⾼系统安全性&#xff0c;通过在 OpenSSH 服务器上禁⽤密码⾝份验证来强制进⾏基于密钥的⾝份验证。 1、一台虚拟机无需密码连接另一台虚拟机 .ssh目录 > 保存了ssh相关的key和一些记录文件 &#xff08;1&#xff09;生成密钥对 使⽤这个流程在本地…

U盘打不开的终极解决方案:原因剖析、恢复策略与预防之道

U盘困境&#xff1a;打不开的焦虑与应对 在数字化时代&#xff0c;U盘作为数据交换与存储的重要工具&#xff0c;几乎成为了每个人工作、学习和生活中的必需品。然而&#xff0c;当您满怀期待地将U盘插入电脑&#xff0c;却遭遇“无法识别”、“无法访问”等提示&#xff0c;U…

【人工智能】Transformers之Pipeline(一):音频分类(audio-classification)

​​​​​​​ 目录 一、引言 二、音频分类&#xff08;audio-classification&#xff09; 2.1 概述 2.2 技术原理 2.2.1 Wav2vec 2.0模型 2.2.1 HuBERT模型 2.3 pipeline参数 2.3.1 pipeline对象实例化参数 2.3.2 pipeline对象使用参数 2.4 pipeline实战 2.4.1 …

【Qt 基础】Qt Creator 的初步使用、创建项目的过程

文章目录 1. Qt SDK 中工具程序的介绍2. 创建第一个 Qt 项目的前置步骤 1. Qt SDK 中工具程序的介绍 下载之后会出现下面几个程序&#xff1a; Assistant 表示 Qt 自带的离线官方文档&#xff1b; Designer &#xff1a;Qt设计师&#xff0c;图形化的设计界面的工具&#xf…

C++程序进阶学习

目录 引言 C内存分区 一、内存分区模型 二、 程序运行前 三、程序执行后 C引用 引用的语法 作用 本质 优点 C封装 C对象特性 C对象模型和this指针 C友元 C运算符重载 C继承 C多态 C文件 引言 看过我博客的朋友可能都了解这篇文章内容了&#xff0c;这篇博…

超声波清洗机哪家好?家用超声波眼镜清洗机推荐

超声波清洗机现在已经成为了很多家庭的新宠&#xff0c;它能够帮助我们轻松解决日常生活中的清扫烦恼。但是&#xff0c;面对市面上品种繁多的清洗机产品&#xff0c;我们该如何选择一款适合自己的呢?毕竟不同的品牌和型号&#xff0c;在清洗效果、噪音水平、除菌能力等方面都…

RHCE-autofs自动挂载

要求 一、在主机上提供web&#xff0c;dns服务 服务端 IP&#xff1a;172.25.250.131/24 dns&#xff1a;172.25.250.131 [rootlocalhost ~]# cd /etc/httpd/conf.d[rootlocalhost conf.d]# vim vhost.conf [rootlocalhost conf.d]# mkdir /nfs/rhce -p[rootlocalhost conf…

雪深监测站的工作原理

TH-TS200雪深监测站是一种用于测量和记录雪层深度的设备&#xff0c;它在气象观测、交通管理、防灾减灾、水源管理等多个领域发挥着重要作用。雪深监测用来监测雪深的设备。它通过各种传感器和测量设备&#xff0c;如超声波测距仪、激光测距仪、压力传感器等&#xff0c;获取雪…

若依安装和初始化教程(傻瓜教程 一步一步走)

1、若依的安装&#xff1a; 1、找到若依官方网站并选择若依的前后端分离版本 2、点击克隆 然后选择http进行复制 3、打开idea 如果有打开的项目就先关闭项目&#xff0c;然后就会自动弹出下面第二张图片&#xff0c;接着按照流程走就可以 到此若依的下载就成功了 2、若依项目…

如何判断代码是否是在UPDATE TASK的Session中执行?

1. 背景 有时我们想控制ABAP代码在UPDATE TASK中的逻辑&#xff0c;例如某些逻辑执行&#xff0c;某些逻辑不执行。 那么&#xff0c;我们应该如何判断当前代码运行的环境呢&#xff1f;也即&#xff0c;怎么知道一段运行时代码是运行在当前的ABAP session中&#xff0c;还是…

IDEA设置代码提示忽略大小写

一、设置代码提示为忽略大小写 IDEA代码提示默认是区分大小写的&#xff0c;设置为提示忽略大小写&#xff1a; Setting——Editor——Code Completion 如图

智慧金融-数据可视化

智慧金融-数据可视化 导入所需的库 import numpy as np import numpy_financial as npf import matplotlib.pyplot as plt from pylab import mpl mpl.rcParams[font.sans-serif][FangSong] mpl.rcParams[axes.unicode_minus]False单图曲线图 r 0.05 # 贷款的年利率 n 30…