国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 10:55:58
字體:
來源:轉載
供稿:網友

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

原理:

A:放大鏡   B:小圖片

C:大圖片可視區域

D:大圖片

鼠標的位置應該在放大鏡的中央,所以鼠標位置為:

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

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

鼠標移動過程中:放大鏡A和大圖D是一起隨鼠標成比例運動的,因為當放大鏡A的右邊框移動到與小圖B的右邊框重合時,大圖D也應該移動到了右邊框與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的關系,注意區分zhezhao.onmousemove=function(ev){var event=evvar 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>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广东省| 土默特左旗| 扶余县| 烟台市| 通渭县| 甘泉县| 新河县| 隆尧县| 富宁县| 徐水县| 禄劝| 普兰店市| 金门县| 辉南县| 富蕴县| 长武县| 颍上县| 赞皇县| 楚雄市| 呼伦贝尔市| 孝义市| 云安县| 霸州市| 醴陵市| 澜沧| 丁青县| 共和县| 金坛市| 东阳市| 象山县| 晋江市| 丰顺县| 襄樊市| 淳安县| 满城县| 麟游县| 会宁县| 即墨市| 钦州市| 政和县| 乐陵市|