原生js 放大鏡特效
阿新 • • 發佈:2019-02-18
最近在做ecshop的二次開發,遇到一些jquery外掛與ecshop的衝突,
調整衝突的需要修改的地方又太多,修改起來得不償失,
故做了一個原生的js實現商品詳情頁面的放大鏡效果,以避免衝突!
下面介紹一下程式碼及實現過程:
首先,建立fangda.html檔案
在檔案頭部的<head></head>中新增檔案的css樣式,即:
<style type="text/css"> #div1 { width:304px; height:222px; position:relative; margin:30px auto 0px; border:2px solid red;} #div1 img{width:304px; height:222px;} #div1 span { width:100px; height:100px; background:red; left:0px;top:0px; position:absolute; display:none; filter:alpha(opacity:20); opacity:0.2;} .show { width:100%; height:100%; background:red; position:absolute; z-index:10px; filter:alpha(opacity:10); opacity:0.1; left:0px; top:0px; } #div2 {width:304px; height:222px; position:relative; display:none; overflow:hidden; margin:0px auto 0px;} #img1 { position:absolute;} </style> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <title>JavaScript 圖片放大程式碼</title>
設定,顯示在頁面的內容
<body> <div id="div1"> <img src="images/big/1.jpg" /> <!-- 本地圖片路徑 --> <span></span> <!-- 滑鼠滑動 放大區域 --> <div class="show"></div> </div> <div id="div2"> <!-- 展示放大後的圖片 --> <img id="img1" src="images/big/1.jpg" /> <!-- 本地大圖片路徑 --> </div> </body>
然後,新增js事件效果,新增在<head></head>中
<script type="text/javascript"> //通過頁面載入事件,使頁面載入完畢自動執行 window.onload=function () { var oDiv=document.getElementById('div1'); var oShow=oDiv.getElementsByTagName('div')[0]; var oSpan=oDiv.getElementsByTagName('span')[0]; var oImg=document.getElementById('img1'); oShow.onmouseover=function() { oSpan.style.display='block'; oImg.parentNode.style.display='block'; }; oShow.onmouseout=function() { oSpan.style.display='none'; oImg.parentNode.style.display='none'; }; oShow.onmousemove=function(ev) { var oEvent=ev||event; var x=oEvent.clientX-oDiv.offsetLeft-oSpan.offsetWidth/2; var y=oEvent.clientY-oDiv.offsetTop-oSpan.offsetHeight/2; //獲得具體座標 if(x<0) { x=0; } else if(x>oShow.offsetWidth-oSpan.offsetWidth) { x=oShow.offsetWidth-oSpan.offsetWidth; } if(y<0) { y=0; } else if(y>oShow.offsetHeight-oSpan.offsetHeight) { y=oShow.offsetHeight-oSpan.offsetHeight } oSpan.style.left=x+'px'; oSpan.style.top=y+'px'; var percentX=x/(oShow.offsetWidth-oSpan.offsetWidth); var percentY=y/(oShow.offsetHeight-oSpan.offsetHeight); var oImgparent=oImg.parentNode; oImg.style.left=-percentX*(oImg.offsetWidth-oImgparent.offsetWidth)+'px'; oImg.style.top=-percentY*(oImg.offsetHeight-oImgparent.offsetHeight)+'px'; }; }; </script>
這樣就實現了,圖片移上後的放大效果,同時由於沒有引入其他的外掛,移植性比較好,
可以通過更改較少的程式碼,就較好地規避在其他專案和商城中的衝突。
但缺點沒有引入外掛後效果華麗,載入頁面沒有引入外掛的快,
可以考慮在這個頁面做一個快取,增加使用者二次訪問速度!