1. 程式人生 > 程式設計 >JavaScript仿京東放大鏡效果

JavaScript仿京東放大鏡效果

本文例項為大家分享了實現京東放大鏡效果的具體程式碼,供大家參考,具體內容如下

案例分析

  • 整個案例可以分為三個功能模組
  • 滑鼠經過小圖片盒子, 黃色的遮擋層 和 大圖片盒子顯示,離開隱藏2個盒子功能
  • 黃色的遮擋層跟隨滑鼠功能。
  • 移動黃色遮擋層,大圖片跟隨移動功能。
  • 滑鼠經過小圖片盒子, 黃色的遮擋層 和 大圖片盒子顯示,離開隱藏2個盒子功能
  • 就是顯示與隱藏

JavaScript仿京東放大鏡效果

  • 移動黃色遮擋層,大圖片跟隨移動功能,大圖片的移動距離要跟黃色遮擋層的比例相等。
  • 求大圖片的移動距離公式

JavaScript仿京東放大鏡效果

程式碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width,initial-scale=1.0">
    <title>Document</title>
    <style>
        .preview_wrap {
            width: 400px;
            height: 400px;
        }

        .preview_img {
        ZAjowRq
position: relative; height: 398px; border: 1px solid #ccc; } .mask { display: none; position: absolute; top: 0; left: 0; width: 300px; height: 300px; background: #FEDE4F; opacity: .5; border: 1px solid #ccc; cursor: move; } .big { display: none; position: absolute; left: 410px; top: 0; width: 500px; height: 500px; background-color: pink; z-index: 999; border: 1px solid #ccc; overflow: hidden; } /* 要給圖片加了絕對定位,才可以設定 left top */ .big img { position: absolute; top: 0; left: 0; } </style> </head> <body> <div class="preview_wrap"> <div class="preview_img"> <img src="images/s3.png" alt="Script仿京東放大鏡效果"> <div class="mask"></div> <div class="big"> <img src="images/big.jpg" alt="JavaScript仿京東放大鏡效果" class="bigImg"> </div> </div> </div> <script> var preview_img = document.querySelector('.preview_img'); var mask = document.querySelector('.mask'); var big = document.querySelector('.big'); // 1. 當我們滑鼠經過 preview_img 就顯示和隱藏 mask 遮擋層 和 big 大盒子 preview_img.addEventListener('mouseover',function() { mask.style.display = 'block'; big.style.display = 'block'; }) preview_img.addEventListener('mouseout',function() { mask.style.display = 'none'; big.style.display = 'none'; }) // 2. 滑鼠移動的時候,讓黃色的盒子跟著滑鼠來走 preview_img.addEventListener('mousemove',function(e) { // (1). 先計算出滑鼠在盒子內的座標 var x = e.pageX - this.offsetLeft; var y = e.pageY - this.offsetTop; // console.log(x,y);
// (2) 減去盒子高度 300的一半 是 150 就是我們mask 的最終 left 和top值了 // (3) 我們mask 移動的距離 var maskX = x - mask.offsetWidth / 2; var maskY = y - mask.offsetHeight / 2; // (4) 如果x 座標小於了0 就讓他停在0 的位置 // 遮擋層的最大移動距離 var maskMax = preview_img.offsetWidth - mask.offsetWidth; if (maskX <= 0) { maskX = 0; } else if (maskX >= maskMax) { maskX = maskMax; } if (maskY <= 0) { maskY = 0; } else if (maskY >= mas
kMax) { maskY = maskMax; } mask.style.left = maskX + 'px'; mask.style.top = maskY + 'px'; // 3. 大圖片的移動距離 = 遮擋層移動距離 * 大圖片最大移動距離 / 遮擋層的最大移動距離 // 大圖 var bigIMg = document.querySelector('.bigImg'); // 大圖片最大移動距離 var bigMax = bigIMg.offsetWidth - big.offsetWidth; // 大圖片的移動距離 X Y var bigX = maskX * bigMax / maskMax; var bigY = maskY * bigMax / maskMax; bigIMgZAjowRq.style.left = bigX + 'px'; bigIMg.style.top = bigY + 'px'; }) </script> </body> </html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。