首頁 > 軟體

利用JavaScript實現仿京東放大鏡效果

2022-03-08 13:02:36

功能實現

1、滑鼠經過小圖片盒子,黃色的遮擋層和大圖片顯示,離開時就隱藏2個盒子功能

2、黃色遮擋層跟著滑鼠走

把滑鼠的座標給盒子,不斷地進行賦值操作

把滑鼠地座標給遮擋層不合適,因為遮擋層座標以父盒子為準

首先是獲得滑鼠在盒子內地座標

然後把數值給遮擋層地left和top值

此時用到滑鼠移動事件,但是還是在小圖片盒子內移動

發現,遮擋層位置不對,需要再減去盒子自身高度和寬度地一半

遮擋層不能超出小圖片盒子範圍

如果小於0,就把座標設定為0

如果大於遮擋層最大地移動距離,就把座標設定為最大地移動距離

遮擋層地最大移動距離:小圖片盒子寬度減去遮擋層盒子寬度

3、移動黃色遮擋層,大盒子跟著圖片走

也太難了、、、、

<!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>
        .box {
            width: 300px;
            height: 300px;
            position: relative;
            border: 1px solid #ccc;
        }
        
        .tupian {
            width: 100%;
            height: 100%;
        }
        /* 不能是box裡面所有地img百分百比例,這樣是無法再大盒子裡面移動圖片地 */
        
        .mask {
            display: none;
            width: 150px;
            height: 150px;
            background: rgba(228, 248, 138, 0.3);
            position: absolute;
            top: 0px;
            left: 0px;
            cursor: move;
        }
        
        .big {
            display: none;
            width: 400px;
            height: 400px;
            position: absolute;
            top: 0px;
            left: 310px;
            background-color: pink;
            overflow: hidden;
        }
        
        .big img {
            position: absolute;
            top: 0px;
            left: 400px
        }
    </style>
</head>
 
<body>
    <div class="box"><img src="http://img14.360buyimg.com/n1/s450x450_jfs/t1/131049/21/21277/105207/61dfcd46E2318f45d/32bd21d7732845bc.jpg" alt="" class="tupian">
        <div class="mask"></div>
        <div class="big"><img src="http://img14.360buyimg.com/n1/s450x450_jfs/t1/131049/21/21277/105207/61dfcd46E2318f45d/32bd21d7732845bc.jpg" alt="" class="bigimg"></div>
    </div>
 
    <script>
        //當滑鼠放在box上,箭頭變為移動
        var tupian = document.querySelector('.tupian')
        var mask = document.querySelector('.mask')
        var big = document.querySelector('.big')
        var box = document.querySelector('.box')
        var bigimg = document.querySelector('.bigimg')
            //滑鼠放在小圖片上時,黃色遮擋層顯示以及大盒子顯示
        box.addEventListener('mouseover', function() { //不能是圖片新增的事件,因為mask一顯示就會把圖片給擋住
                mask.style.display = 'block'
                big.style.display = 'block'
            })
            //滑鼠離開小圖片,就隱藏
        box.addEventListener('mouseout', function() {
            mask.style.display = 'none'
            big.style.display = 'none'
        })
        box.addEventListener('mousemove', function(e) {
            //先計算出滑鼠在盒子內地座標
            var x = e.pageX - box.offsetLeft
            var y = e.pageY - box.offsetTop
                //減75(盒子地一般)是為了讓滑鼠位於盒子地中心
                //mask移動地距離
            var maskx = x - mask.offsetWidth / 2
            var masky = y - mask.offsetHeight / 2 //最好這樣賦值一下,就不用考慮if裡面地單位情況
                //約束--設定小盒子移動範圍
            if (maskx <= 0) {
                maskx = 0
            } else if (maskx >= box.offsetWidth - mask.offsetWidth) {
                maskx = box.offsetWidth - mask.offsetWidth
            }
            if (masky <= 0) {
                masky = 0
            } else if (masky >= box.offsetHeight - mask.offsetHeight) {
                masky = box.offsetHeight - mask.offsetHeight
            }
            mask.style.left = maskx + 'px'
            mask.style.top = masky + 'px'
            var maxMax = box.offsetWidth - mask.offsetWidth //遮擋層地最大移動距離
            var bigMax = bigimg.offsetWidth - big.offsetWidth //大圖片地最大移動距離
                //大圖片地移動距離
            var bigx = maskx * bigMax / maxMax
            var bigy = masky * bigMax / maxMax
            bigimg.style.left = -bigx + 'px'
            bigimg.style.top = -bigy + 'px'
        })
 
 
 
 
 
 
 
        // tupian.addEventListener('mouseover', function() {
        //     tupian.addEventListener('mousemove', function(e1) {
        //         mask.style.display = 'block'
        //         var x = e1.pageX - tupian.offsetLeft
        //         var y = e1.pageY - tupian.offsetTop
        //         mask.style.left = x - 75 + 'px'
        //         mask.style.top = y - 75 + 'px'
        //         if (mask.style.bottom < -10) {
        //             mask.style.bottom = 0 + 'px'
        //         }
        //     })
 
        //讓遮罩層跟隨滑鼠移動
        // div.addEventListener('mousemove', function(e) {
        //     var a = e.pageX - div.offsetLeft
        //     var b = e.pageY - div.offsetTop
        //     if (a > 75) {
        //         mask.style.left = e.pageX - div.offsetLeft - x + 'px'
        //     }
        //     if (mask.style.left < 0) {
        //         mask.style.left = 0
        //     }
        //     if (b > 75) {
        //         mask.style.top = e.pageY - y + 'px'
        //     }
        //     if (mask.style.top < 0) {
        //         mask.style.top = 0
        //     }
        // mask.style.left = x - 75 + 'px' //滑鼠並不一定要在mask的正中間
        // mask.style.top = y - 75 + 'px'
 
        // div.addEventListener('mousemove', fn)
 
        // function fn(e) { //這個函數一定要寫在mousedown函數裡面才能取出x和y
        //     //不能讓白色遮罩層出box盒子
        //     mask.style.left = e.pageX - x - 75 + 'px'
        //     mask.style.top = e.pageY - y - 75 + 'px'
        // }
        // })
 
 
        //滑鼠離開盒子就取消移動事件
        // div.addEventListener('mouseout', function() {
 
        // div.removeEventListener('mousemove', fn)
        // })
        // })
    </script>
</body>
 
</html>

覆盤:

<!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>
        .box {
            width: 300px;
            height: 300px;
            position: relative;
        }
        
        .pre {
            width: 100%
        }
        
        .mask {
            display: none;
            position: absolute;
            top: 0px;
            left: 0px;
            width: 100px;
            height: 150px;
            background-color: pink;
            opacity: 0.3;
        }
        
        .big {
            /* display: none; */
            position: absolute;
            top: 0px;
            left: 310px;
            width: 400px;
            height: 400px;
            background-color: pink;
            overflow: hidden;
            /* 當大盒子裡面地圖片出來地時候,就將出來部分地圖片進行隱藏 */
        }
        /* 滑鼠進入小盒子地時候,變為移動 */
        
        .bigtu {
            position: absolute;
            top: 0px;
            left: 0px;
        }
        
        .box:hover {
            cursor: move
        }
    </style>
</head>
 
<body>
    <div class="box">
        <img src="http://img14.360buyimg.com/n1/s450x450_jfs/t1/131049/21/21277/105207/61dfcd46E2318f45d/32bd21d7732845bc.jpg" alt="" class="pre">
        <div class="mask"></div>
        <div class="big"> <img src="http://img14.360buyimg.com/n1/s450x450_jfs/t1/131049/21/21277/105207/61dfcd46E2318f45d/32bd21d7732845bc.jpg" alt="" class="bigtu"></div>
    </div>
    <script>
        //1、滑鼠進入小盒子,遮罩層、大盒子出現
        var box = document.querySelector('.box')
        var mask = document.querySelector('.mask')
        var big = document.querySelector('.big')
        var bigtu = document.querySelector('.bigtu')
        box.addEventListener('mouseover', function() {
                mask.style.display = 'block'
                big.style.display = 'block'
            })
            //2、滑鼠離開小盒子地時候,遮罩層、大盒子隱藏
        box.addEventListener('mouseout', function() {
                mask.style.display = 'none'
                big.style.display = 'none'
            })
            //3、新增移動效果,遮罩層跟隨滑鼠移動,滑鼠再小盒子地座標就是遮罩層地位置
        box.addEventListener('mousemove', function(e) {
            //求滑鼠在小盒子裡面地座標
            var x = e.pageX - box.offsetLeft
            var y = e.pageY - box.offsetTop
                //將滑鼠地座標給遮罩層
                // mask.style.left = x + 'px'
                // mask.style.top = y + 'px'
                //滑鼠應該位於遮罩層地中心位置
            var maskx = x - mask.offsetWidth / 2
            var masky = y - mask.offsetHeight / 2
 
            //4、應該約束遮罩層地移動範圍,也就是約束滑鼠地位置,maskx、masky要大於0,以及要小於一個值,不能初到底部下面或者右邊地右邊
            if (maskx < 0) {
                maskx = 0
            }
            if (maskx > box.offsetWidth - mask.offsetWidth) {
                maskx = box.offsetWidth - mask.offsetWidth
            }
            if (masky < 0) {
                masky = 0
            }
            if (masky > box.offsetHeight - mask.offsetHeight) {
                masky = box.offsetHeight - mask.offsetHeight
            }
            mask.style.left = maskx + 'px'
            mask.style.top = masky + 'px'
                //5、要讓大盒子裡面地圖片移動,加相對定位.原理滑鼠在小盒子裡面移動地距離與滑鼠在大盒子裡面移動地距離是成比例地.其實就是小盒子圖片地left、top值與大盒子裡面地left、top值是成比例地   弄清楚這個比例關係很重要
            var bigtux = maskx * (bigtu.offsetWidth - big.offsetWidth) / (box.offsetWidth - mask.offsetWidth)
            var bigtuy = masky * (bigtu.offsetHeight - big.offsetHeight) / (box.offsetHeight - mask.offsetHeight)
            bigtu.style.left = -bigtux + 'px'
            bigtu.style.top = -bigtuy + 'px'
                //應該也要對大盒子裡面地圖片移動範圍進行約束
                //忽視了一點:bigtu地大小是450*450地,所以大盒子不能直接等於450*450;應該小於450*450;這樣圖片在大盒子裡面才有移動地餘地
                //相當於左側地小盒子,對圖片進行了縮小,需要在大盒子裡面顯示原始圖片,位置對應
        })
    </script>
</body>
 
</html>

以上就是利用JavaScript實現仿京東放大鏡效果的詳細內容,更多關於JavaScript放大鏡效果的資料請關注it145.com其它相關文章!


IT145.com E-mail:sddin#qq.com