您好,登錄后才能下訂單哦!
本文實(shí)例講述了原生JS實(shí)現(xiàn)的放大鏡特效。分享給大家供大家參考,具體如下:
最近在做ecshop的二次開發(fā),遇到一些jquery插件與ecshop的沖突,
調(diào)整沖突的需要修改的地方又太多,修改起來得不償失,
故做了一個(gè)原生的js實(shí)現(xiàn)商品詳情頁面的放大鏡效果,以避免沖突!
下面介紹一下代碼及實(shí)現(xiàn)過程:
首先,創(chuàng)建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>
設(shè)置,顯示在頁面的內(nèi)容
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <title>JavaScript 圖片放大代碼</title> <body> <div id="div1"> <img src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地圖片路徑 --> <span></span> <!-- 鼠標(biāo)滑動(dòng) 放大區(qū)域 --> <div class="show"></div> </div> <div id="div2"> <!-- 展示放大后的圖片 --> <img id="img1" src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地大圖片路徑 --> </div> </body>
然后,添加js事件效果,添加在<head></head>
中
<script type="text/javascript"> //通過頁面加載事件,使頁面加載完畢自動(dòng)執(zhí)行 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; //獲得具體坐標(biāo) 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>
這樣就實(shí)現(xiàn)了,圖片移上后的放大效果,同時(shí)由于沒有引入其他的插件,移植性比較好,可以通過更改較少的代碼,就較好地規(guī)避在其他項(xiàng)目和商城中的沖突。
但缺點(diǎn)沒有引入插件后效果華麗,加載頁面沒有引入插件的快,
可以考慮在這個(gè)頁面做一個(gè)緩存,增加用戶二次訪問速度!
這里使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試運(yùn)行效果如下:
感興趣的朋友可以使用上述在線工具測試一下看看運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript圖片操作技巧大全》、《JavaScript運(yùn)動(dòng)效果與技巧匯總》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。