亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript實現圖片放大鏡效果的方法

發布時間:2021-04-12 10:39:00 來源:億速云 閱讀:158 作者:小新 欄目:web開發

這篇文章主要介紹了JavaScript實現圖片放大鏡效果的方法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

具體內容如下

1、結構布局HTML代碼

<div class="leftcon" id="left">
 <img src="~/Content/images/風景-1.jpg" />
 <div class="slide_box" id="box"></div>
</div>
<div class="rightcon" id="right">
 <img src="~/Content/images/風景-1.jpg" />
</div>

2、修飾結構css樣式代碼

img {
display: block;
}.leftcon {
width: 350px;height: 350px;
margin: 100px 20px 0px 312px;
float: left;position: relative;
box-shadow: 3px 3px 10px 0 #111111; /*給圖片施加陰影效果 */
-webkit-box-shadow: 3px 3px 10px 0 #111111; /*兼容性處理*/
-moz-box-shadow: 3px 3px 10px 0 #111111;
}.leftcon img {
width: 100%;height: 100%;
}.leftcon .slide_box {
display: none; /*將小方塊盒子隱藏*/
position: absolute;top: 0;left: 0;
width: 175px;height: 175px;
background: #000;opacity: 0.3;
cursor: move; /*改變鼠標的形狀*/
}.rightcon {
display: none; /*將右邊div隱藏*/
width: 350px;height: 350px;
margin-top: 100px;float: left;
overflow: hidden;position: relative;
}.rightcon img {
width: 200%;height: 200%;
position: absolute;left: 0px;top: 0px;
}

3、js獲取事件對象

1)、Event是獲取事件對象,對象代表事件的狀態,比如事件在其中發生的元素、鍵盤按鍵的狀態、
鼠標的位置、鼠標按鈕的狀態,envet是windows的一個屬性。 放大鏡實現方法(獲取右邊圖片定位)
2)、e.clientY:返回事件觸發時鼠標相對于元素視口的Y坐標。
e.clientX:返回事件觸發時鼠標相對于元素視口的X坐標。
這里的元素視口實際上代指就是瀏覽器,clientX是鼠標距離瀏覽器左邊框的距離,
clientY是鼠標距離瀏覽器上邊框的距離。
offsetTop獲取對象相對于版面或由offsetTop屬性指定的父坐標的計算頂端位置。
這里就是左邊的div相對于body即瀏覽器窗口的縱向距離
offsetLeft獲取對象相對于版面或由offsetLeft屬性指定的父坐標的計算頂端位置。
這里就是左邊的div相對于body即瀏覽器窗口的縱橫向距離
offsetHeight是對象的可見高度。這里是指小滑塊的高度
offsetHeight是對象的可見寬度。這里是指小滑塊的寬度

var leftone = document.getElementById('left');
var rightone = document.getElementById('right');
var box = document.getElementById('box');
var rimg = rightone.getElementsByTagName("img")[0];
function getPosition(e){ //這里的參數e就是代表event
 //首先我們要去判斷事件源,獲取事件源,也就是e
 var e=e||window.event; //實現兼容
 //理解:
 //這個表達式寫全是這樣:var e=event?event||window.event;
 //如果存在event,那么var e=event;而如果不存在event,
 //那么var e=window.event.那么可以看出確實能實現兼容
 var top = e.clientY-leftone.offsetTop-box.offsetHeight/2; 
 //計算小圖容器里的鼠標坐標(要減去最外層的偏移)
 var left = e.clientX-leftone.offsetLeft-box.offsetWidth/2;
 //這里為什么除以2?是因為我們不除以2的話,事件源也就是鼠標就在這個小滑塊的的右下角,并不美觀
 //我們要讓鼠標位于滑塊的中心,所以寬高各減去一半

  //邊界判斷
  //獲取小滑塊最大縱向移動距離
  var maxtop = leftone.offsetHeight - box.offsetHeight; 
  //獲取小滑塊最大橫向移動距離
  var maxleft = leftone.offsetWidth - box.offsetWidth; 
  var mintop = 0; //獲取小滑塊最小縱向移動距離
  var minleft = 0; //獲取小滑塊最大縱向移動距離
  var mvtop; //定義小滑塊的縱向移動距離
  var mvleft; //定義小滑塊的橫向移動距離
  // 判斷
  if (top<mintop) {
  box.style.top = mintop + "px";
   mvtop = mintop;
   //理解:
 //top是鼠標到瀏覽器的垂直距離-左邊div頂部到瀏覽器的垂直距離-小滑塊的高度的一半。
 //那么現在鼠標在小滑塊的中心,也就是說,top就等于小滑塊的頂部到左邊div的垂直距離
 //如果top<0,就是說小滑塊和左邊div頂部重合,就讓小滑塊的top值為0,即鼠標繼續向上移動,
 //小滑塊不在移動,從而讓小滑塊的移動范圍不能超過左邊div的寬高范圍
 //下方同理
  }else if(top>maxtop){
   box.style.top = maxtop + "px";
   mvtop = maxtop;
 //如果top>maxtop,就是說小滑塊和左邊div底部重合,就讓小滑塊的top值為maxtop,
 //即鼠標繼續向下移動,小滑塊不在移動,從而讓小滑塊的移動范圍不能超過左邊div的寬高范圍
  }else{
   box.style.top = top + "px";
   mvtop = top;
   //不超過邊界,則小滑塊的垂直移動距離就等于top,即小滑塊的頂部到左邊div的垂直距離
  }
  if(left<minleft){
   box.style.left = minleft + "px";
   mvleft = minleft
  }else if(left>maxleft){
   box.style.left = maxleft + "px";
   mvleft = maxleft
  }else{
   box.style.left = left + "px";
   mvleft = left;
  }
 //因為右邊div的圖片是左邊div的圖片的兩倍,而左邊div和右邊div都是小滑塊的寬高的兩倍,
 //而要讓右邊div放大左邊的小滑塊的包圍圖片,所以右邊大圖的定位坐標是小滑塊的兩倍,這樣才能進行映射
 //右側圖片跟著運動:左側小滑塊移動多少,右側跟著移動他的2倍即可
  rimg.style.top = -mvtop*2 + "px";
  rimg.style.left = -mvleft*2 + "px";
 }

4、鼠標移入、移出事件

左側盒子鼠標移入,小滑塊和右側圖片顯示,銜接鼠標移動效果
onmouseenter 事件類似于 onmouseover 事件。 唯一的區別是 onmouseenter 事件不支持冒泡。

//鼠標移動效果
leftone.onmousemove = function(e){
 var e=e||window.event; //判斷事件源
 box.style.display = "block";
  getPosition(e);
 rightone.style.display = "block";
}
//鼠標移出效果
leftone.onmouseleave = function(e){
 var e=e||window.event; //判斷事件源
  box.style.display = "none";
  rightone.style.display = "none";
}

5、效果圖

JavaScript實現圖片放大鏡效果的方法

感謝你能夠認真閱讀完這篇文章,希望小編分享的“JavaScript實現圖片放大鏡效果的方法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

奉节县| 东台市| 望都县| 定边县| 固安县| 迁安市| 盐山县| 白水县| 樟树市| 东乌珠穆沁旗| 贡嘎县| 冷水江市| 长春市| 乌兰县| 苏州市| 上林县| 思茅市| 辛集市| 莆田市| 古蔺县| 本溪| 苏尼特左旗| 紫阳县| 台中市| 莆田市| 葫芦岛市| 高密市| 铜梁县| 霞浦县| 乌拉特后旗| 铁岭县| 阿克苏市| 顺义区| 富平县| 禹城市| 饶河县| 皮山县| 醴陵市| 伽师县| 盘锦市| 湖口县|