其他分享
首页 > 其他分享> > js 放大镜案例

js 放大镜案例

作者:互联网

分析和解释都在代码行上

在这里插入图片描述

<!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>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        .box {
            margin-left: 100px;
            height: 1000px;
        }

        .box_left {
            position: relative;
            width: 300px;
        }

        .box_left>img {
            width: 300px;
        }

        .box_right {
            display: none;
            position: absolute;
            top: 0;
            left: 410px;
            width: 400px;
            height: 600px;
            border: 1px solid #333;
            overflow: hidden;
        }

        .box_right>img {
            position: absolute;
            left: 0;
            top: 0;
            /* width: 600px; */
            /* width: 300px; */
        }

        .meak {
            display: none;
            position: absolute;
            top: 0;
            left: 0;
            width: 200px;
            height: 200px;
            background: yellow;
            opacity: .5;
        }
    </style>
</head>

<body>
    <div class="box">
        <div class="box_left">
            <img src="./imgaes/1_poster.4aa4c624.jpg" alt="">
            <div class="meak"></div>
        </div>
        <div class="box_right">
            <img id="banimg" src="./imgaes/1_poster.4aa4c624.jpg" alt="">
        </div>
    </div>
    <script>
        // 案例分析
        // 鼠标移入时 放大镜显示(黄色盒子 和 放大的图显示
        // 因 放大镜 定位在了 产品图的上面 他的 lef 和 top 作用于他的父盒子
        // 我们需要计算出 鼠标在盒子内的 坐标 然后把坐标 给 放大镜 的 left 和 top
        // 我们需要让 放大镜 在产品图 盒子里进行移动 并显示 和隐藏
        // 大图分析案例在下面对应的代码行

        // 先获取属性
        var box_left = document.querySelector('.box_left')
        var meak = document.querySelector('.meak')
        var box_right = document.querySelector('.box_right')
        var banimg = document.querySelector('#banimg')
        
        // 注册事件 鼠标移入事件
        box_left.addEventListener('mouseover', function () {
            meak.style.display = 'block'
            box_right.style.display = 'block'
        })

        // 注册事件 鼠标移动事件
        box_left.addEventListener('mousemove', function (e) {
            // 获取鼠标在盒子内的坐标
            var x = e.pageX - this.offsetLeft
            var y = e.pageY - this.offsetTop

            // 让放大镜盒子 自身向 x 和 y 方向移动自身宽和高的一半 从而得到盒子的移动距离
            var meakx = x - meak.offsetWidth / 2
            var meaky = y - meak.offsetHeight / 2

            // 这里计算出 放大镜在这个 盒子移动的极限距离 (也就是放大镜不能移动出这个盒子)
            // 用 产品图的 宽和高 减去 盒子的宽和高 就可以得到 盒子的 left 和 top 的最大值
            var widthX = this.offsetWidth - meak.offsetWidth
            var heightY = this.offsetHeight - meak.offsetHeight
            // 然后用 if 来判断 
            // 当盒子的 x 小于等于0 就让 盒子的 x 值为 0
            // 当盒子的 y 大于等于的 left 的极限值 就让 y = left 
            if (meakx <= 0) {
                meakx = 0
            } else if (meakx >= widthX) {
                meakx = widthX
            }
            if (meaky <= 0) {
                meaky = 0
            } else if (meaky >= heightY) {
                meaky = heightY
            }
            meak.style.left = meakx + 'px'
            meak.style.top = meaky + 'px'

            // 现在我们要让大图也跟着移动

            // 我们可以利用 产品图与大盒子的比例来判断
            //   放大镜的移动距离          大盒子的移动距离
            // ------------------   ==  ------------------ 
            // 放大镜的极限移动距离       大盒子的极限移动距离

            // 现在我们已知的条件有 
            // 放大镜的移动距离、放大镜的极限移动距离、大盒子的极限移动距离

            // 所以我们可以推算出 
            // 大盒子的移动移动距离 = 放大镜的移动距离 * 大盒子的极限移动距离 / 放大镜的极限移动距离

            var maximgX = box_right.offsetWidth - banimg.offsetWidth // 大盒子的极限距离 X
            var maxX = meakx * maximgX / widthX // 大盒子的移动移动距离 X
            var maximgY = box_right.offsetHeight - banimg.offsetHeight // 大盒子的极限距离 Y
            var maxY = meaky * maximgY / heightY // 大盒子的移动移动距离 Y

            // 这里说明一下 大图在移动的时候是与放大镜反方向移动的 所以移动的值为负值 
            // 我的产品图宽为 300 所以给大图设置了 600 的宽 (当然你不设置也没有问题,但前提得是你的大图的宽高一定要大于产品图,如果你的大图 宽高小于或等于了 产品图 那么在 maxX 和 maxY 的面膜要加 - ,将 left 和 top 变成负值)
            banimg.style.left = maxX + 'px'
            banimg.style.top = maxY + 'px'
        })

        // 注册事件 移出事件
        box_left.addEventListener('mouseout', function () {
            meak.style.display = 'none'
            box_right.style.display = 'none'
        })
    </script>
</body>

</html>

标签:box,盒子,放大镜,js,案例,var,移动,left
来源: https://blog.csdn.net/A951299034/article/details/120734242