js实现简单放大镜效果


Posted in Javascript onMarch 07, 2020

用js实现简单放大镜效果,供大家参考,具体内容如下

此处放大镜实现的效果就是当鼠标放置在图片上会有半透明遮罩,图片的一个区域就会被放大,然后展示在右边。当鼠标移动时右边的大图片也会局部移动。这里的放大并不是真正的放大,而是等比例移动。下面是实现的代码:

css样式代码如下:

<style>
 .s_box{width:400px;height: 300px;position: absolute;left: 50px;top:100px;}
 .s_box img{width: 400px;height: 300px;}
 .s_box span{width: 130px;height: 100px;background: rgba(200,200,200,0.5);position: absolute;left:0;top:0;display: none;cursor:move;}

 .b_box{width: 400px;height: 300px;overflow: hidden;position: absolute;left:500px;top:100px;display: none;}
 .b_box img{width: 1200px;height: 900px;position: absolute;left:0;top:0;}

 .list{margin: 0;padding: 0;list-style: none;position: absolute;left:50px;top:430px;}
 .list li{float: left;margin: 0 10px;}
 .list li img{width: 100px;height: 80px;}
</style>

html代码如下:

<body>
 <div class="s_box">
 <img src="../img/large1.jpg" alt="">
 <span></span>
 </div>
 <div class="b_box">
 <img src="../img/large1.jpg" alt="">
 </div>
 <ul class="list">
 <li><img src="../img/large1.jpg" alt=""></li>
 <li><img src="../img/large2.jpg" alt=""></li>
 </ul>
</body>

js主要代码如下:

// 分析:
// 1.选择元素
// 2.绑定事件
// 3.进入的时候显示元素
// 4.移动:遮罩层跟随鼠标移动的同时计算遮罩层的移动比例 、右侧大图,等比例移动
// 5.离开的时候隐藏元素 
<script>
 class Large{
 constructor(){
 this.sBox = document.querySelector(".s_box");
 this.sImg = document.querySelector(".s_box img");
 this.sSpan = document.querySelector(".s_box span");
 this.bBox = document.querySelector(".b_box");
 this.bImg = document.querySelector(".b_box img");
 // 点击小图切换大图的按钮
 this.li = document.querySelectorAll(".list li");
 }
 addEvent(){
 var that = this;
 this.sBox.onmouseover = function(){
 that.over();
 }
 this.sBox.onmousemove = function(eve){
 var e = eve || window.event;
 that.move(e);
 }
 this.sBox.onmouseout = function(){
 that.out();
 }
 // 切换图片按钮的点击事件:根据布局做出调整
 for(var i=0;i<this.li.length;i++){
 this.li[i].onclick = function(){
  that.sImg.src = this.children[0].src;
  that.bImg.src = this.children[0].src;
 }
 }
 }
 over(){
 this.sSpan.style.display = "block";
 this.bBox.style.display = "block";
 }
 move(e){
 // 计算遮罩层跟随鼠标移动时的left和top
 var l = e.pageX - this.sBox.offsetLeft - this.sSpan.offsetWidth/2;
 var t = e.pageY - this.sBox.offsetTop - this.sSpan.offsetHeight/2;
 // 边界限定
 if(l<0) l=0;
 if(t<0) t=0;
 if(l > this.sBox.offsetWidth - this.sSpan.offsetWidth){
 l = this.sBox.offsetWidth - this.sSpan.offsetWidth;
 }
 if(t > this.sBox.offsetHeight - this.sSpan.offsetHeight){
 t = this.sBox.offsetHeight - this.sSpan.offsetHeight;
 }
 // 设置遮罩层的位置
 this.sSpan.style.left = l + "px";
 this.sSpan.style.top = t + "px";
 // 根据遮罩层移动的距离计算比例
 var x = l / (this.sBox.offsetWidth - this.sSpan.offsetWidth);
 var y = t / (this.sBox.offsetHeight - this.sSpan.offsetHeight);
 // 根据上一步得到的比例,计算右侧大图要移动的当前值
 this.bImg.style.left = (this.bBox.offsetWidth - this.bImg.offsetWidth) * x + "px";
 this.bImg.style.top = (this.bBox.offsetHeight - this.bImg.offsetHeight) * y + "px";
 }
 out(){
 this.sSpan.style.display = "none";
 this.bBox.style.display = "none";
 }
 }

 // 启动
 var l = new Large();
 l.addEvent();

</script>

实现效果:

js实现简单放大镜效果

更多关于放大镜的精彩文章,请点击链接查看:《放大镜效果》

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

Javascript 相关文章推荐
IE与Firefox下javascript getyear年份的兼容性写法
Dec 20 Javascript
js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
Dec 27 Javascript
node.js中的http.response.writeHead方法使用说明
Dec 14 Javascript
js实现鼠标悬浮给图片加边框的方法
Jan 30 Javascript
解决bootstrap中modal遇到Esc键无法关闭页面
Mar 09 Javascript
Bootstrap CSS组件之分页(pagination)和翻页(pager)
Dec 17 Javascript
Element-ui tree组件自定义节点使用方法代码详解
Sep 17 Javascript
使用Javascript简单计算器
Nov 17 Javascript
vue 列表页跳转详情页获取id以及详情页通过id获取数据
Mar 27 Javascript
Element Input输入框的使用方法
Jul 26 Javascript
JavaScript快速调试的两个技巧
Nov 04 Javascript
JavaScript实现简单计时器
Jun 22 Javascript
js实现文字头像的生成代码
Mar 07 #Javascript
JavaScript队列结构Queue实现过程解析
Mar 07 #Javascript
原生JS实现萤火虫效果
Mar 07 #Javascript
JavaScript实现轮播图片完整代码
Mar 07 #Javascript
JS实现瀑布流效果
Mar 07 #Javascript
Vue中使用better-scroll实现轮播图组件
Mar 07 #Javascript
JavaScript实现栈结构Stack过程详解
Mar 07 #Javascript
You might like
php对包含html标签的字符串进行截取的函数分享
2014/06/19 PHP
php用正则判断是否为数字的方法
2016/03/25 PHP
关于php中一些字符串总结
2016/05/05 PHP
PHP实现大数(浮点数)取余的方法
2017/02/18 PHP
基于JavaScript实现智能右键菜单
2016/03/02 Javascript
实例详解ECMAScript5中新增的Array方法
2016/04/05 Javascript
第五章之BootStrap 栅格系统
2016/04/25 Javascript
微信小程序 教程之条件渲染
2016/10/18 Javascript
vue loadmore组件上拉加载更多功能示例代码
2017/07/19 Javascript
JS实现页面打印(整体、局部)
2017/08/18 Javascript
基于Particles.js制作超炫粒子动态背景效果(仿知乎)
2017/09/13 Javascript
使用vue的transition完成滑动过渡的示例代码
2018/06/25 Javascript
js中实例与对象的区别讲解
2019/01/21 Javascript
详解vue-cli3多环境打包配置
2019/03/28 Javascript
Vue项目history模式下微信分享爬坑总结
2019/03/29 Javascript
jquery实现的分页显示功能示例
2019/08/23 jQuery
jQuery实现鼠标滑动切换图片
2020/05/27 jQuery
JS实现数据动态渲染的竖向步骤条
2020/06/24 Javascript
Ant design vue中的联动选择取消操作
2020/10/31 Javascript
[01:57]2016完美“圣”典风云人物:国士无双专访
2016/12/04 DOTA
python爬虫框架scrapy实战之爬取京东商城进阶篇
2017/04/24 Python
Python 基础教程之闭包的使用方法
2017/09/29 Python
python dataframe 输出结果整行显示的方法
2018/06/14 Python
python使用多进程的实例详解
2018/09/19 Python
python 读取Linux服务器上的文件方法
2018/12/27 Python
如何基于pythonnet调用halcon脚本
2020/01/20 Python
python有几个版本
2020/06/17 Python
python如何代码集体右移
2020/07/20 Python
奠基仪式主持词
2014/03/20 职场文书
个人批评与自我批评发言稿
2014/09/28 职场文书
扬州个园导游词
2015/02/06 职场文书
外出听课学习心得体会
2016/01/15 职场文书
转变工作作风心得体会
2016/01/23 职场文书
2016年第十四个公民道德宣传日活动总
2016/04/01 职场文书
pandas取dataframe特定行列的实现方法
2021/05/24 Python
Java字符串逆序方法详情
2022/03/21 Java/Android