欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生JS實現(xiàn)的放大鏡特效示例【測試可用】

 更新時間:2018年12月08日 09:35:46   作者:JSON_L  
這篇文章主要介紹了原生JS實現(xiàn)的放大鏡特效,涉及javascript事件響應(yīng)及頁面元素動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下

本文實例講述了原生JS實現(xiàn)的放大鏡特效。分享給大家供大家參考,具體如下:

最近在做ecshop的二次開發(fā),遇到一些jquery插件與ecshop的沖突,

調(diào)整沖突的需要修改的地方又太多,修改起來得不償失,

故做了一個原生的js實現(xiàn)商品詳情頁面的放大鏡效果,以避免沖突!

下面介紹一下代碼及實現(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)滑動 放大區(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">
//通過頁面加載事件,使頁面加載完畢自動執(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>

這樣就實現(xiàn)了,圖片移上后的放大效果,同時由于沒有引入其他的插件,移植性比較好,可以通過更改較少的代碼,就較好地規(guī)避在其他項目和商城中的沖突。

但缺點沒有引入插件后效果華麗,加載頁面沒有引入插件的快,

可以考慮在這個頁面做一個緩存,增加用戶二次訪問速度!

這里使用在線HTML/CSS/JavaScript代碼運行工具http://tools.jb51.net/code/HtmlJsRun測試運行效果如下:

 

感興趣的朋友可以使用上述在線工具測試一下看看運行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript圖片操作技巧大全》、《JavaScript運動效果與技巧匯總》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

  • JavaScript設(shè)置獲取和設(shè)置屬性的方法

    JavaScript設(shè)置獲取和設(shè)置屬性的方法

    這篇文章主要介紹了JavaScript設(shè)置獲取和設(shè)置屬性的方法,學(xué)會使用getAttribute、setAttribute的用法,需要的朋友可以參考下
    2015-03-03
  • JS實現(xiàn)簡易的圖片拖拽排序?qū)嵗a

    JS實現(xiàn)簡易的圖片拖拽排序?qū)嵗a

    這篇文章主要介紹了JS實現(xiàn)簡易的圖片拖拽排序?qū)嵗a,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • JS中prototype關(guān)鍵字的功能介紹及使用示例

    JS中prototype關(guān)鍵字的功能介紹及使用示例

    prototype 關(guān)鍵字可以為JS原有對象或者自己創(chuàng)建的類中添加方法或者屬性。也可以實現(xiàn)繼承,下面以實例的方式為大家詳細(xì)介紹下
    2013-07-07
  • js實現(xiàn)圖片從左往右漸變切換效果的方法

    js實現(xiàn)圖片從左往右漸變切換效果的方法

    這篇文章主要介紹了js實現(xiàn)圖片從左往右漸變切換效果的方法,是比較典型的圖片漸變切換效果特效,非常具有實用價值,需要的朋友可以參考下
    2015-02-02
  • JavaScript Reduce使用詳解

    JavaScript Reduce使用詳解

    這篇文章主要介紹了JavaScript Reduce使用的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下
    2021-03-03
  • JS 跳轉(zhuǎn)頁面延遲2種方法

    JS 跳轉(zhuǎn)頁面延遲2種方法

    js跳轉(zhuǎn)頁面想必大家不會很陌生吧,在瀏覽頁面的時候經(jīng)常會碰到這種現(xiàn)象存在如果可以延遲的話是不是會更委婉一點呢,接下來為大家介紹下如何實現(xiàn),感興趣的朋友可以參考下哈
    2013-03-03
  • 小程序新版訂閱消息模板消息

    小程序新版訂閱消息模板消息

    這篇文章主要介紹了小程序新版訂閱消息模板消息,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 探索JavaScript中私有成員的相關(guān)知識

    探索JavaScript中私有成員的相關(guān)知識

    這篇文章主要介紹了探索JavaScript中私有成員的相關(guān)知識,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,,需要的朋友可以參考下
    2019-06-06
  • 原生JS利用transform實現(xiàn)banner的無限滾動示例代碼

    原生JS利用transform實現(xiàn)banner的無限滾動示例代碼

    這篇文章主要介紹了原生JS利用transform實現(xiàn)banner的無限滾動示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 10個實用的腳本代碼工具

    10個實用的腳本代碼工具

    10個實用的腳本工具,其實就是將代碼拷貝到IE地址欄中運行
    2010-05-05

最新評論