前端必学——实现电商图片放大镜效果(附代码)

简介: 放大镜可以说是前端人必须学会的程序之一,今天的案例为大家展示一下怎么实现放大镜的效果!效果图展示  整个效果就是当鼠标放到展示图上的时候,会出现一个遮罩层以及弹出来一个框展示一个详情图,并且鼠标移动的时候详情图跟着移动,鼠标离开详情图消失。

放大镜可以说是前端人必须学会的程序之一,今天的案例为大家展示一下怎么实现放大镜的效果!

效果图展示

 整个效果就是当鼠标放到展示图上的时候,会出现一个遮罩层以及弹出来一个框展示一个详情图,并且鼠标移动的时候详情图跟着移动,鼠标离开详情图消失。

fcbc5bab8f1370bb8ec27be3abff513.png



fdbc7e9eab4a69237b8f4d95c5bbe82.png



HTML代码:

<html>

<head>

<style>

#small{

   width: 500px;

   height: 312px;

   position: absolute;

   left: 20px;

   top: 20px;

}

#pic1{

   position: absolute;

   left: 0px;

   top: 0px;

}

#pic1 img{

   width: 100%;

   height: 100%;

}

#big{

   width: 200px;

   height: 200px;

   position: absolute;

   left: 550px;

   top: 50px;

   border: 1px solid blue;

   overflow: hidden;

}

#pic2{

   width: 1000px;

   height: 625px;

   position: absolute;

   left: 0;

   top: 0;

}

#pic2 img{

   width: 100%;

   height: 100%;

}

#mask{

   width: 100px;

   height: 100px;

   background: black;

   opacity: 0.3;/*让遮罩层看起来透明*/

   filter: alpha(opacity = 30);/*兼容不同的浏览器*/

   position: absolute;

   display: none;

}

</style>

<script>

window.onload = function(){//文档内容加载完之后再执行

   //当鼠标移入小图片,显示遮罩层和放大的区域

   $('small').onmouseenter = function(){

       $('mask').style.display = 'block';

       $('big').style.display='block';

   }

       //鼠标移出时,隐藏遮罩层和放大的区域

   $('small').onmouseleave = function(){

       $('mask').style.display='none';

       $('big').style.display="none";

   }

   //鼠标移动

   $('small').onmousemove = function(ev){

       var e = ev || window.event;

       //计算鼠标的位置,并让鼠标显示在遮罩层的中间

       var l = e.clientX - $('small').offsetLeft - 50;

       var t = e.clientY - $('small').offsetTop -50;

       //别让遮罩层移出图片

       if(l <= 0){

           l = 0;

       }

       if(l >= 500 - 100){

           l = 400;

       }

       if(t <= 0){

           t = 0;

       }

       if(t >= 312 - 100){

           t = 212;

       }

       //遮罩层的移动

       $('mask').style.left = l + 'px';

       $('mask').style.top = t + 'px';

       //通过遮罩层移动,来计算出放大后图片的显示区域

       $("pic2").style.left = -$("mask").offsetLeft * 2 + 'px';

       $("pic2").style.top = -$("mask").offsetTop * 2 + 'px';

   }

}

//为了更容容易的获取id

function $(id){

   return document.getElementById(id);

}

</script>

</head>

<div id="small">

   <div id="pic1">

       <img src="mm.jpg" alt="">

   </div>

   <div id="mask"></div>

</div>

<div id="big">

   <div id="pic2">

       <img src="mm.jpg" alt="">

   </div>

</div>

 

</html>

相关文章
|
2月前
|
前端开发
若依框架---如何使用多数据源?前端table中如何显示图片?
若依框架---如何使用多数据源?前端table中如何显示图片?
203 2
|
2月前
|
缓存 前端开发 JavaScript
「零基础」掌握Webpack:10个必学技巧,为前端项目保驾护航!(三)
「零基础」掌握Webpack:10个必学技巧,为前端项目保驾护航!
|
3天前
|
前端开发 JavaScript
js 打开资源管理器(经典范例:纯前端选择并预览图片)
js 打开资源管理器(经典范例:纯前端选择并预览图片)
14 0
|
5天前
|
前端开发 UED
前端 CSS 经典:在 Vue3 中使用渐进式图片
前端 CSS 经典:在 Vue3 中使用渐进式图片
9 0
|
5天前
|
JavaScript 前端开发
前端 JS 经典:统一 Vite 中图片转换逻辑
前端 JS 经典:统一 Vite 中图片转换逻辑
7 0
|
5天前
|
前端开发
前端 CSS 经典:图片边框
前端 CSS 经典:图片边框
5 0
|
9天前
|
前端开发 计算机视觉
视觉智能开放平台操作报错合集之人脸对比1:1,采用web前端直接调用,使用了base64处理图片,提示http错误码414,该如何处理
在使用视觉智能开放平台时,可能会遇到各种错误和问题。虽然具体的错误代码和消息会因平台而异,但以下是一些常见错误类型及其可能的原因和解决策略的概述,包括但不限于:1. 认证错误、2. 请求参数错误、3. 资源超限、4. 图像质量问题、5. 服务不可用、6. 模型不支持的场景、7. 网络连接问题,这有助于快速定位和解决问题。
|
2月前
|
XML JSON 前端开发
【Flutter前端技术开发专栏】Flutter中的图片、视频与网络资源加载
【4月更文挑战第30天】Flutter是谷歌的开源前端框架,因其高性能、流畅UI和多端运行能力受开发者喜爱。本文聚焦于Flutter中的资源加载:使用`Image`组件加载静态、网络和本地图片;通过`video_player`库加载和播放视频;利用`http`包进行网络资源请求。掌握这些技巧将有助于提升Flutter应用的开发效率和质量。
【Flutter前端技术开发专栏】Flutter中的图片、视频与网络资源加载
|
2月前
|
前端开发 JavaScript Linux
前端全栈必学的Dockerfile-ABC!
前端全栈必学的Dockerfile-ABC!
40 0
|
2月前
|
前端开发
前端使用多张图片生成 Gif 效果(支持循环、不循环、完成回调)
前端使用多张图片生成 Gif 效果(支持循环、不循环、完成回调)
98 0

热门文章

最新文章