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

嘗試動手制作javascript放大鏡效果

 更新時間:2015年12月25日 09:53:54   作者:Big_Dot  
這篇文章主要介紹了javascript放大鏡效果,照著別人的例子,自己試著做了個放大鏡效果,感興趣的小伙伴們可以參考一下

本文實例為大家介紹了基于javascript實現(xiàn)放大鏡效果的原理和代碼,分享給大家供大家參考,具體內(nèi)容如下:

原理:

A:放大鏡   B:小圖片

C:大圖片可視區(qū)域

D:大圖片

鼠標的位置應(yīng)該在放大鏡的中央,所以鼠標位置為:

clientX=A.offsetLeft()+B.offsetLeft+1/2*A.offsetWidth;

clientY=A.offsetTop()+B.offsetTop+1/2*A.offsetHeight;

鼠標移動過程中:放大鏡A和大圖D是一起隨鼠標成比例運動的,因為當放大鏡A的右邊框移動到與小圖B的右邊框重合時,大圖D也應(yīng)該移動到了右邊框與C的右邊框重合的地方,所以,他們的移動比例是:(D.offsetWidth-C.offsetWidth)/(B.offsetWidth-A.offsetWidth)=b/a

HTML部分:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>放大鏡效果</title>

<style>

*{
margin:0;
padding:0; 
}

#demo{
position: relative;
margin:30px 50px;
width: 1000px;
height: 600px;
border: 1px solid #000;
}

#zhezhao{
position: absolute;
z-index:2;
background:red;
width:402px;
height:402px;
left: 20px;
top:20px;
opacity: 0;
}

#small{
position: absolute;
width:402px;
height:402px;
left: 20px;
top:20px;
border: 1px solid #000;
z-index: 1;
}


#small img{
position: absolute;

}


#big{
position: relative;
top: 20px;
left: 460px;
width:500px;
height:500px;
border: 1px solid #000;
overflow: hidden;
display: none;
z-index: 1;
}


#big img{
position: absolute;

}


#glass{
position: absolute;
width:100px;
height: 100px;
opacity: 0.3;
background:orange;
display: none;
}

</style>


</head>


<body>
<div id='demo'>
<div id='zhezhao'> </div> 
<!-- 在ie瀏覽器中,當鼠標在放大鏡上是,瀏覽器并不認為鼠標同樣在小圖的div上,所以加個遮罩層 兼容ie-->


<div id='small'> 
<img src='images/small.png' alt=''>
<div id='glass'></div>
</div>
<div id='big'>
<img src='images/big.jpg' alt='' >

</div>

</div>



</body>

</html>

js部分:

<script>

window.onload=function(){
var demo =document.getElementById('demo');
var small =document.getElementById('small');
var big =document.getElementById('big');
var glass =document.getElementById('glass')
var image =document.getElementById('big').getElementsByTagName('img')[0];
var zhezhao=document.getElementById('zhezhao');

zhezhao.onmouseover=function(){
glass.style.display='block'
big.style.display='block'
}
zhezhao.onmouseout=function(){
glass.style.display='none'
big.style.display='none'
}

//弄清楚clientX,offsetLeft,left的關(guān)系,注意區(qū)分
zhezhao.onmousemove=function(ev){
var event=ev
var left=event.clientX-demo.offsetLeft-small.offsetLeft-glass.offsetWidth/2;
var top =event.clientY-demo.offsetTop -small.offsetTop -glass.offsetHeight/2;
if(left<0){
left=0;
}else if(left>(small.offsetWidth-glass.offsetWidth)){
left=small.offsetWidth-glass.offsetWidth
}

if(top<0){
top=0;
}else if(top>(small.offsetHeight- glass.offsetHeight)){
top=small.offsetHeight- glass.offsetHeight
}
glass.style.left =left+'px';
glass.style.top =top+'px';

 

var percent=(image.offsetWidth-big.offsetWidth)/(small.offsetWidth-glass.offsetWidth)

image.style.left=-percent*left+'px'
image.style.top =-percent*top+'px'



}
}

</script>

以上就是本文的全部內(nèi)容,希望對大家實現(xiàn)javascript放大鏡效果有所幫助。

相關(guān)文章

  • JavaScript手寫數(shù)組的常用函數(shù)總結(jié)

    JavaScript手寫數(shù)組的常用函數(shù)總結(jié)

    這篇文章主要給大家介紹了關(guān)于JavaScript手寫數(shù)組常用函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • js實現(xiàn)多張圖片延遲加載效果

    js實現(xiàn)多張圖片延遲加載效果

    這篇文章主要為大家詳細介紹了js實現(xiàn)多張圖片延遲加載效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • mui上拉加載功能實例詳解

    mui上拉加載功能實例詳解

    最近小編在做移動端的項目,用到了mui的上拉加載功能,今天小編給大家整理一下分享到腳本之家平臺,需要的朋友參考下
    2017-04-04
  • 淺談jQuery異步對象(XMLHttpRequest)

    淺談jQuery異步對象(XMLHttpRequest)

    文章淺顯易懂的將jQuery異步對象分為了5個步奏,非常有利于我們學(xué)習(xí)記憶,是篇相當不錯的學(xué)習(xí)jQuery異步對象的文章,這里推薦給大家。
    2014-11-11
  • Three.js中實現(xiàn)Bloom效果及完整示例

    Three.js中實現(xiàn)Bloom效果及完整示例

    這篇文章主要為大家介紹了Three.js中實現(xiàn)Bloom效果及完整示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • javascript中undefined與null的區(qū)別

    javascript中undefined與null的區(qū)別

    在JavaScript中存在這樣兩種原始類型:Null與Undefined。這兩種類型常常會使JavaScript的開發(fā)人員產(chǎn)生疑惑,在什么時候是Null,什么時候又是Undefined?
    2015-08-08
  • 利用 Chrome Dev Tools 進行頁面性能分析的步驟說明(前端性能優(yōu)化)

    利用 Chrome Dev Tools 進行頁面性能分析的步驟說明(前端性能優(yōu)化)

    這篇文章主要介紹了利用 Chrome Dev Tools 進行頁面性能分析的步驟說明(前端性能優(yōu)化),本文給大家介紹的非常想詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • 原生js模擬購物車功能

    原生js模擬購物車功能

    這篇文章主要為大家詳細介紹了原生js模擬購物車功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • JavaScript數(shù)據(jù)結(jié)構(gòu)之棧實例用法

    JavaScript數(shù)據(jù)結(jié)構(gòu)之棧實例用法

    在本篇文章里小編給大家分享了關(guān)于JavaScript數(shù)據(jù)結(jié)構(gòu)之棧實例用法內(nèi)容,有興趣的朋友們學(xué)習(xí)下。
    2019-01-01
  • JavaScript實現(xiàn)簡易的天數(shù)計算器實例【附demo源碼下載】

    JavaScript實現(xiàn)簡易的天數(shù)計算器實例【附demo源碼下載】

    這篇文章主要介紹了JavaScript實現(xiàn)簡易的天數(shù)計算器,結(jié)合實例形式分析了javascript日期與時間計算的相關(guān)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下
    2017-01-01

最新評論