Web开发 —— 放大镜效果(HTML、CSS、JavaScript)
创始人
2024-12-29 12:39:00
0

目录

一、需求描述

二、实现效果

三、完整代码

四、实现过程

1、HTML 页面结构

2、CSS 元素样式

3、JavaScript动态控制

(1)获取元素

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

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

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

(5)显示放大图


一、需求描述

前端实现放大镜效果;

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

二、实现效果

初始效果

放大效果

三、完整代码

【test.html】

                  放大镜效果             

四、实现过程

1、HTML 页面结构

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

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

     

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元素的方式之一;

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

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

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

分析需求可知:

  • 遮罩层和大图盒子的显示与隐藏是同时的,大图盒子显示则遮罩层显示,大图盒子隐藏则遮罩层隐藏;
  • 当鼠标经过原图时,两者显示,需要给这个原图盒子注册鼠标经过事件,完成相应功能;
  • 当鼠标移出原图时,两者隐藏,也需要给这个原图盒子注册鼠标移出事件,完成相应功能;

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

分析需求可知:

  • 遮罩层在盒子内的移动距离,实际就是鼠标的移动距离(遮罩层跟着鼠标移动),但注意这个是遮罩层左上角的位置;
  • 遮罩层中心的移动距离,要在鼠标移动距离的基础上,减去遮罩层自身的宽度或高度;
  • 鼠标的移动距离mouseX\mouseY为,鼠标在页面中的X坐标\Y坐标 - 图片盒子的左\上边距;
  • 注意,这里鼠标一开始进入图片盒子就开始计算;

注意:

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

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

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

分析需求可知:

  • 遮罩层的移动距离不能小于 0,也不能超过它的最大移动距离;
  • 遮罩层最大移动宽度\高度 = 原图盒子的宽度\高度 - 遮罩层的宽度\高度;
  • 如果移动距离 大于 最大移动距离,则取最大的移动距离;
  • 如果移动距离 小于 0,则取0;

(5)按比例移动放大图

分析需求可知:

  • 放大比例 = 原图的宽度 / 大图的宽度;
  • 大图的移动距离 = 遮罩层的移动距离 * 放大比例;
  • 注意:大图的移动方向与遮罩层相反;

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

每天进步一点点~!

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

相关内容

热门资讯

六分钟指南书!边锋小程序透视器... 六分钟指南书!边锋小程序透视器,方片十三张外g挂(辅助)切实真的有安装(哔哩哔哩)1)边锋小程序透视...
第6分钟办法!指尖捕鱼bgm,... 您好,新518互游脚本这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩...
5分钟妙计!陕麻圈免费辅助软件... 5分钟妙计!陕麻圈免费辅助软件,新西游大厅拼十辅助(辅助)其实是真的工具(哔哩哔哩)1、点击下载安装...
第9分钟烘培!椰子大厅辅助脚本... 第9分钟烘培!椰子大厅辅助脚本,超级三加一视频(辅助)总是有挂app(哔哩哔哩)1、很好的工具软件,...
第6分钟要领!广西老友修改器,... 第6分钟要领!广西老友修改器,天酷互娱有辅助工具嘛(辅助)都是是真的修改器(哔哩哔哩)亲,关键说明,...
5分钟手段!火神微信辅助,新玄... 5分钟手段!火神微信辅助,新玄龙辅助工具(辅助)一直真的是有下载(哔哩哔哩)所有人都在同一条线上,像...
第六分钟攻略!欢乐情怀辅助器,... 第六分钟攻略!欢乐情怀辅助器,随意玩俱乐部辅助(辅助)真是是有神器(哔哩哔哩)1、随意玩俱乐部辅助透...
第2分钟教材!山西扣点子的技巧... 第2分钟教材!山西扣点子的技巧,财神13章作必弊码大全(辅助)确实真的有工具(哔哩哔哩)财神13章作...
7分钟办法!微友助手app下载... 7分钟办法!微友助手app下载辅助器,新星游辅助怎么购买(辅助)一贯真的是有辅助器(哔哩哔哩)1、微...
第8分钟操作!心悦踢坑辅助器服... 第8分钟操作!心悦踢坑辅助器服务器码,新天道辅助脚本(辅助)都是是真的脚本(哔哩哔哩)1、进入到心悦...