快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

原生js如何实现商品放大镜效果-创新互联

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

创新互联公司长期为千余家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为霞山企业提供专业的成都网站建设、成都网站制作霞山网站改版等技术服务。拥有10多年丰富建站经验和众多成功案例,为您定制开发。

实现原理

大图上的放大镜:小图的显示区域=大图片大小:小图片大小=大图片的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如何实现商品放大镜效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前名称:原生js如何实现商品放大镜效果-创新互联
标题网址:http://6mz.cn/article/ceopso.html

免费获取网站建设与品牌策划方案报价

*主要业务范围包括:高端网站建设, 集团网站建设(网站建设网站制作)找网站建设公司就上快上网。
提交需求

    联系我们

    028-86922220
  • 手机:13518219792
  • 地址:成都市太升南路288号锦天国际A幢1002号
  • 24小时服务热线:400-028-6601

    网站建设服务

  • 网页设计
  • 网站制作
  • 网站开发

    网站推广服务

  • 营销网站建设
  • 百度快速排名
  • 整站网站推广

    网站运维服务

  • 基础维护
  • 网站改版
  • 网站维护

    FOLLOW US

  • 微信二维码

    微信二维码

Copyright © 2022 成都快上网科技有限公司 成都网站建设公司-选网站建设公司快上网!国内专业的网站制作公司!
All Rights Reserved 版权所有 蜀ICP备19037934号-11