真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

原生js如何實現(xiàn)商品放大鏡效果

這篇文章將為大家詳細講解有關原生js如何實現(xiàn)商品放大鏡效果,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:主機域名、網頁空間、營銷軟件、網站建設、薛城網站維護、網站推廣。

實現(xiàn)原理

大圖上的放大鏡:小圖的顯示區(qū)域=大圖片大?。盒D片大小=大圖片的offsetLeft:小圖片的offsetLeft

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

代碼中有詳細注釋

完整代碼

注:復制到本地后自行替換圖片查看效果





demo




  
    
    
       
             //在頁面加載完后立即執(zhí)行多個函數(shù)方案   function addloadEvent(func){     var oldonload=window.onload;     if(typeof window.onload !="function"){       window.onload=func;     }     else{       window.onload=function(){         if(oldonload){           oldonload();          }         func();       }     }   }   //在頁面加載完后立即執(zhí)行多個函數(shù)方案結束   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如何實現(xiàn)商品放大鏡效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。


當前標題:原生js如何實現(xiàn)商品放大鏡效果
標題網址:http://weahome.cn/article/gposgj.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部