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

嘗試動(dòng)手制作javascript放大鏡效果

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

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

原理:

A:放大鏡   B:小圖片

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

D:大圖片

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

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

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

鼠標(biāo)移動(dòng)過程中:放大鏡A和大圖D是一起隨鼠標(biāo)成比例運(yùn)動(dòng)的,因?yàn)楫?dāng)放大鏡A的右邊框移動(dòng)到與小圖B的右邊框重合時(shí),大圖D也應(yīng)該移動(dòng)到了右邊框與C的右邊框重合的地方,所以,他們的移動(dòng)比例是:(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瀏覽器中,當(dāng)鼠標(biāo)在放大鏡上是,瀏覽器并不認(rèn)為鼠標(biāo)同樣在小圖的div上,所以加個(gè)遮罩層 兼容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>

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

相關(guān)文章

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

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

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

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

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

    mui上拉加載功能實(shí)例詳解

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

    淺談jQuery異步對(duì)象(XMLHttpRequest)

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

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

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

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

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

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

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

    原生js模擬購(gòu)物車功能

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

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

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

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

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

最新評(píng)論