189 8069 5689

原生js如何实现商品放大镜效果

这篇文章将为大家详细讲解有关原生js如何实现商品放大镜效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:主机域名、网页空间、营销软件、网站建设、薛城网站维护、网站推广。

实现原理

大图上的放大镜:小图的显示区域=大图片大小:小图片大小=大图片的offsetLeft:小图片的offsetLeft

那么以上的公式中只有大图片的offsetLeft 是未知的,所以大图片的offsetLeft=大图片大小/小图片大小*小图片的offsetLeft

代码中有详细注释

完整代码

注:复制到本地后自行替换图片查看效果





demo




  
    
    
       
             //在页面加载完后立即执行多个函数方案   function addloadEvent(func){     var oldonload=window.onload;     if(typeof window.onload !="function"){       window.onload=func;     }     else{       window.onload=function(){         if(oldonload){           oldonload();          }         func();       }     }   }   //在页面加载完后立即执行多个函数方案结束   addloadEvent(b);   function b(){    //获取外围容器    var demo=document.getElementById("demo");    //获取小图片容器    var s_Box=document.getElementById("small-box");    //获取大图片容器    var b_Box=document.getElementById("big-box");    //获取大图片    var b_Image=b_Box.getElementsByTagName("img")[0];    //获取放大镜    var f_Box=document.getElementById("float-box");    //覆盖在最上面的盖板为鼠标移动用    var mark=document.getElementById("mark");    //移入放大镜和大图片容器显示    mark.onmouseover=function(){    f_Box.style.display="block";    b_Box.style.display="block";    }    //移出放大镜和大图片容器隐藏    mark.onmouseout=function(){    f_Box.style.display="none";    b_Box.style.display="none";    }    //移动事件    mark.onmousemove=function(ev){    //获取鼠标坐标window兼容ie    var e=ev||window.event;    //当前鼠标x轴-容器相对body偏移量-小容器相对父容器偏移值-放大镜宽度的一半=放大镜的当前位置    var left=e.clientX-demo.offsetLeft-s_Box.offsetLeft-f_Box.offsetWidth/2;    //公式同上    var top=e.clientY-demo.offsetTop-s_Box.offsetTop-f_Box.offsetHeight/2;    //判断当放大镜移出容器时在边缘显示    if(left<0){     left=0;    }else if(left>(s_Box.offsetWidth-f_Box.offsetWidth)){     left=s_Box.offsetWidth-f_Box.offsetWidth;    }    if(top<0){     top=0;    }else if(top>(s_Box.offsetHeight-f_Box.offsetHeight)){     top=s_Box.offsetHeight-f_Box.offsetHeight;    }    //放大镜当前位置    f_Box.style.left=left+"px";    f_Box.style.top=top+"px";    //获取比例    var z=b_Image.offsetWidth/s_Box.offsetWidth;    //用放大镜偏移量*比例=大图片的偏移量,方向相反所以负值    b_Image.style.left=-left*z+"px";    b_Image.style.top=-top*z+"px";    }   }

关于“原生js如何实现商品放大镜效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


网站栏目:原生js如何实现商品放大镜效果
网页地址:http://cdxtjz.cn/article/gposgj.html

联系我们

您好HELLO!
感谢您来到成都网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
  • 电话:028- 86922220 18980695689
  • 商务合作邮箱:631063699@qq.com
  • 合作QQ: 532337155
  • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

小谭建站工作室

成都小谭网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,小谭建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

小谭观点

相对传统的成都网站建设公司而言,小谭是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。