原生JS實現的放大鏡特效示例詳解
文章轉載於:http://www.codingke.com/article/4316
首先比如在做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/">JavaScript 圖片放大程式碼</title>
<body>
<div id="div1">
<img src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地圖片路徑 -->
<span></span> <!-- 滑鼠滑動 放大區域 -->
<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">
//通過頁面載入事件,使頁面載入完畢自動執行
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>
這樣就實現了,圖片移上後的放大效果,同時由於沒有引入其他的外掛,移植性比較好,可以通過更改較少的程式碼,就較好地規避在其他專案和商城中的衝突。
以上就是關於扣丁學堂HTML5/">HTML5培訓之原生JS實現的放大鏡特效示例詳解,希望對小夥伴們有所幫助,想要了解更多內容的小夥伴可以登入扣丁學堂官網諮詢。扣丁學堂有專業老師制定的HTML5學習路線圖輔助學員學習,此外還有專業老師講解的HTML5視訊直播課供大家學習,想要學好HTML5開發技術的小夥伴快快行動吧。扣丁學堂H5技術交流群:673883249。