原生JS怎么实现放大镜效果

这篇文章给大家分享的是有关原生JS怎么实现放大镜效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

10多年的商城网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。全网整合营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整商城建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“商城网站设计”,“商城网站推广”以来,每个客户项目都认真落实执行。

具体内容如下



 
 
 
 
 * {
 margin: 0;
 padding: 0;
 }
 img{
 vertical-align: top;
 }
 .fdj {
 width: 350px;
 height: 350px;
 position: relative;
 margin: 100px auto;
 border: 1px solid gainsboro;
 }
 .small {
 position: relative;
 }
 .small img {
 width: 350px;
 }
 .mask {
 width: 100px;
 height: 100px;
 background: rgba(255, 255, 0, 0.4);
 position: absolute;
 left: 0;
 top: 0;
 cursor: move;
 display: none;
 }
 .big {
 position: absolute;
 top: 0;
 left: 360px;
 width: 500px;
 height: 500px;
 border: 1px solid gainsboro;
 overflow: hidden;
 display: none;
 }
 .big img{
 position: absolute;
 left: 0;
 top: 0;
 }
 
 

 
 
 
 
 
 
     
 
     var fdj = document.querySelector('.fdj') // 获得最大的盒子  var small = document.querySelector('.small'); //获取小图片盒子  var big = document.querySelector('.big'); //获取大图片盒子  var bigs = big.children[0] //大图片   var smalls = small.children[0] //小图片  var mask = small.children[1]; //遮罩  //鼠标移入小图片盒子  small.onmouseover = function() {  //鼠标移入图片盒子将遮罩与大图片显示  mask.style.display = 'block';  big.style.display = ' block';  };  //鼠标移出小图片盒子  small.onmouseout = function() {  //鼠标移出小图片盒子将遮罩与大图片隐藏  mask.style.display = 'none';  big.style.display = 'none';  };  var x=0;  var y=0;  //鼠标在小图片上移动时  small.onmousemove = function(ev) {  var ev = event || window.event;  //让鼠标在遮罩正中  //鼠标X坐标与Y坐标  x = ev.clientX -this.offsetParent.offsetLeft- mask.offsetWidth / 2 ;   y = ev.clientY -this.offsetParent.offsetTop- mask.offsetHeight / 2 ;  //将遮罩限制在小图片盒子中  if (x<0) {  x=0;  }else if(x>small.offsetWidth-mask.offsetWidth){  x = small.offsetWidth-mask.offsetWidth;  }  if(y<0){  y=0;  }else if(y>small.offsetHeight-mask.offsetHeight){  y= small.offsetHeight-mask.offsetHeight  }  mask.style.left = x + 'px';  mask.style.top = y + 'px';  //大图与小图的比例  /*var scalX = bigs.offsetWidth/small.offsetWidth;  var scalY = bigs.offsetHeight/small.offsetHeight;*/  var scalX = x/(small.offsetWidth-mask.offsetWidth);  var scalY = y/(small.offsetHeight-mask.offsetHeight);  bigs.style.left = -(x*scalX)+'px';  bigs.style.top = -(y*scalY)+'px';  };  

效果图:(演示)

原生JS怎么实现放大镜效果

感谢各位的阅读!关于“原生JS怎么实现放大镜效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


文章名称:原生JS怎么实现放大镜效果
路径分享:http://pcwzsj.com/article/pgdegg.html

其他资讯