【JavaScript】实战案例-放大镜效果、图片切换

目录

实现这种图片切换的和放大镜的效果: 

第一步:图片的切换

第二步:鼠标经过中等盒子,显示隐藏大盒子

第三步:黑色遮罩盒子跟着鼠标来移动

遮罩层盒子移动的坐标:

总结一下~本章节对我有很大的收获,希望对你也是!!!


素材自取,一定要手码三遍!!!素材自取 

实现这种图片切换的和放大镜的效果: 

 

放大镜样例

 

第一步:图片的切换

1.实现图片的切换以及小li的active类的删除和增加 

2.对小li的active增删后,即可得到当前小li图片的地址:

console.log(e.target.src)

3.对middle图片地址进行更换即可:

middle.querySelector('img').src = e.target.src

第二步:鼠标经过中等盒子,显示隐藏大盒子

1.用到鼠标经过和离开,鼠标经过中盒子,大盒子利用display来显示和隐藏

2.鼠标离开不会立马消失,而是有200ms的延时,用户体验更好,所以经量使用定时器做一个延时setTimeout

3.显示和隐藏也经量定义一个函数,因为鼠标经过离开中等盒子,会显示隐藏,同时,鼠标经过大盒子,也会显示和隐藏

4.给大盒子里面的背景图片一个默认的第一张图片

第三步:黑色遮罩盒子跟着鼠标来移动

1.先做鼠标经过小盒子small盒子,显示隐藏黑色遮罩的盒子

2.让黑色遮罩跟着鼠标来走,需要用到鼠标移动事件mousemove

3.让黑色盒子的移动的核心思想:不断把鼠标在small盒子内的坐标给黑色遮罩层,这样遮罩层就可以跟着移动了

算法:

1)得到鼠标在页面中的坐标,利用事件对象的pageX

2)得到middle中等盒子在页面中的坐标 middle.getBoundingClientRect()

3)鼠标在middle盒子中的坐标 = 鼠标在页面中的坐标 - middle中等盒子的坐标

4)黑色遮罩层不断得到 鼠标在middle盒子中的坐标 就可以移动起来了

4.限定遮罩层的盒子只能在millde内部移动,需要添加判断:

1)限定水平方向 大于等于0 并且小于等于400

2)限定垂直方向 大于等于0 并且小于等于400

遮罩层盒子移动的坐标:

1)声明一个mx作为移动的距离

2)水平坐标x如果小于等于100,则移动的距离mx就是 0 不应该移动

3)水平座标 如果大于等于100 并且小于300, 移动的距离就是mx - 100 (100是遮罩层盒子自身宽度的一半)

4)水平坐标 如果大于等于300 ,移动的距离就是mx从200不约过在移动了

5)其实我们发现水平移动,就在100 ~ 200之间的

6)垂直同理

大盒子800 * 800 的背景图片 跟着middle盒子400 * 400移动 存在关系是2倍

 

我就发现当移动大盒子背景的时候是跟我同方向的,而我们需要它反方向移动,添加负号即可

JavaScript实现:

    const middle = document.querySelector('.middle')
    const small = document.querySelector('.small')
    const large = document.querySelector('.large')


    let img = null
    small.addEventListener('mouseover', function (e) {
      if (e.target.tagName === 'IMG') {
        // 排他思想 干掉以前的
        this.querySelector('.active').classList.remove('active')
        // 先移除以前的active 然后添加当前img父亲<i>标签的active
        e.target.parentNode.classList.add('active')
        // 拿到小盒子里面的图片
        // console.log(e.target.src)
        // 让中等盒子里的图片换成小盒子里的图片即可
        middle.querySelector('img').src = e.target.src
        img = e.target.src
      }
    })


    // 鼠标经过中等盒子,显示隐藏大盒子
    middle.addEventListener('mouseenter', show)
    middle.addEventListener('mouseleave', hide)

    let timeId = null
    function show() {
      clearTimeout(timeId)
      large.style.backgroundImage = `url(${img})`
      large.style.display = 'block'
    }

    function hide() {
      // 延时器
      timeId = setTimeout(function () {
        large.style.display = 'none'
      }, 249)
    }


    large.addEventListener('mouseenter', showLarge)
    large.addEventListener('mouseleave', hideLarge)
    function showLarge() {
      large.style.display = 'block'
    }

    function hideLarge() {
      large.style.display = 'none'
    }



    // 鼠标经过中等盒子,显示隐藏 黑色遮罩层
    const layer = document.querySelector('.layer') //黑色遮罩层
    middle.addEventListener('mouseenter', function () {
      layer.style.display = 'block'
    })

    middle.addEventListener('mouseleave', function () {
      layer.style.display = 'none'
    })

    // 移动黑色遮罩盒子
    middle.addEventListener('mousemove', function (e) {
      // 鼠标在middle内的坐标 = 鼠标在页面的坐标 - middle盒子在页面的坐标
      // console.log(e.pageX)
      // 得到middle盒子在页面中的坐标
      // console.log(middle.getBoundingClientRect().left)
      let x = e.pageX - middle.getBoundingClientRect().left
      let y = e.pageY - middle.getBoundingClientRect().top - document.documentElement.scrollTop
      // console.log(x)
      // console.log(y)
      // 移动黑色遮罩层
      layer.style.left = x + 'px'
      layer.style.top = y + 'px'

      // 黑色遮罩层移动 要在middle黑子内 限定移动距离
      if (x >= 0 && x <= 400 && y >= 0 && y <= 400) {
        // 黑色盒子不是一直移动的
        // 声明两个变量 黑色盒子移动的变量
        let mx = 0, my = 0
        if (x < 100) mx = 0
        if (x >= 100 && x <= 300) mx = x - 100
        if (x > 300) mx = 300 - 100

        if (y < 100) my = 0
        if (y >= 100 && y <= 300) my = y - 100
        if (y > 300) my = 300 - 100
        layer.style.left = mx + 'px'
        layer.style.top = my + 'px'

        // 大盒子800 * 800 的背景图片 跟着middle盒子400 * 400移动 存在关系是2倍
        large.style.backgroundPositionX = -2 * mx + 'px'
        large.style.backgroundPositionY = -2 * my + 'px'
      }
    })

总结一下~本章节对我有很大的收获,希望对你也是!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/972531.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

windows使用clion运行lua文件,并且使用cjson

需要文件&#xff1a;clion&#xff0c;lua-5.4.2_Win64_bin&#xff0c;lua-5.4.2_Win64_dllw6_lib&#xff0c;lua-cjson-2.1.0.9&#xff0c;mingw64 1&#xff0c;下载安装clion。 2&#xff0c;下载lua windows运行程序 lua官网&#xff1a;http://www.lua.org/download…

人工智能基础之数学基础:01高等数学基础

函数 极限 按照一定次数排列的一列数:“&#xff0c;“,…,"…&#xff0c;其中u 叫做通项。 对于数列{Un}如果当n无限增大时&#xff0c;其通项无限接近于一个常数A&#xff0c;则称该数列以A为极限或称数列收敛于A&#xff0c;否则称数列为发散&#xff0c; 极限值 左…

flink-cdc同步数据到doris中

1 创建数据库和表 1.1 数据库脚本 -- 创建数据库eayc create database if not exists ods_eayc; -- 创建数据表2 数据同步 2.1 flnk-cdc 参考Flink CDC实时同步MySQL到Doris Flink CDC 概述 2.1.1 最简单的单表同步 从下面的yml脚本可以看到&#xff0c;并没有doris中创建…

CUDA兼容NVIDA版本关系

CUDA组成 兼容原则 CUDA 驱动(libcuda.so)兼容类型要求比CUDA新向后兼容无主版本一致&#xff0c;子版本旧兼容需要SASS、NVCC比CUDA老向前兼容提取对应兼容包 向后兼容&#xff1a;新版本支持旧版本的内容&#xff0c;关注的是新版本能否处理旧版本的内容。 向前兼容&#…

要配置西门子G120AX变频器实现**端子启停**和**Modbus RTU(485)频率给定

要配置西门子G120AX变频器实现端子启停和Modbus RTU&#xff08;485&#xff09;频率给定&#xff0c;需调整以下关键参数&#xff1a; 1. 端子启停控制 P29652[0]&#xff1a;设置启停信号源 &#xff08;例&#xff1a;P29652 [0] 722.0 表示用DI0端子作为启动/停止信号&…

撕碎QT面具(3):解决垂直布局的内容显示不全

问题&#xff1a;内容显示不全 解决方案&#xff1a;增加Vertical Spacer&#xff0c;它会把Group Box控件挤上去&#xff0c;让内容显示完全。 结果展示&#xff1a;

LabVIEW 中的 ax - events.llb 库

ax - events.llb 库位于C:\Program Files (x86)\National Instruments\LabVIEW 2019\vi.lib\Platform目录&#xff0c;它是 LabVIEW 平台下与特定事件处理相关的重要库。该库为 LabVIEW 开发者提供了一系列工具&#xff0c;用于有效地处理和管理应用程序中的各种事件&#xff0…

Macos机器hosts文件便捷修改工具——SwitchHosts

文章目录 SwitchHosts软件下载地址操作添加方案切换方案管理方案快捷键 检测 SwitchHosts SwitchHosts 是一款 Mac 平台上的免费软件&#xff0c;它可以方便地管理和切换 hosts 文件&#xff0c;支持多种 hosts 文件格式。 软件下载地址 SwitchHosts 操作 添加方案 添加 …

【算法】双指针(下)

目录 查找总价格为目标值的两个商品 暴力解题 双指针解题 三数之和 双指针解题(左右指针) 四数之和 双指针解题 双指针关键点 注意事项 查找总价格为目标值的两个商品 题目链接&#xff1a;LCR 179. 查找总价格为目标值的两个商品 - 力扣&#xff08;LeetCode&#x…

嵌入式linux利用标准字符驱动模型控制多个设备方法

一、驱动模型概述 Linux标准字符设备驱动模型基于以下核心组件: 设备号:由主设备号(Major)和次设备号(Minor)组成 cdev结构体:表征字符设备的核心数据结构 文件操作集合:file_operations结构体定义设备操作 sysfs接口:提供用户空间设备管理能力 传统单设备驱动与多设…

【可实战】Linux 常用统计命令:排序sort、去重uniq、统计wc

在 Linux 系统中&#xff0c;有一些常用的命令可以用来收集和统计数据。 一、常用统计命令的使用场景 日志分析和监控&#xff1a;通过使用 Linux 统计命令&#xff0c;可以实时监控和分析系统日志文件&#xff0c;了解系统的运行状况和性能指标。例如&#xff0c;使用 tail 命…

在 macOS 的 ARM 架构上按住 Command (⌘) + Shift + .(点)。这将暂时显示隐藏文件和文件夹。

在 macOS 的 ARM 架构&#xff08;如 M1/M2 系列的 Mac&#xff09;上&#xff0c;设置 Finder&#xff08;访达&#xff09;来显示隐藏文件夹的步骤如下&#xff1a; 使用快捷键临时显示隐藏文件&#xff1a; 在Finder中按住 Command (⌘) Shift .&#xff08;点&#xff…

分享一个解梦 Chrome 扩展 —— 周公 AI 解梦

一、插件简介 周公 AI 解梦是一款基于 Chrome 扩展的智能解梦工具&#xff0c;由灵机 AI 提供技术支持。它能运用先进的 AI 技术解析梦境含义&#xff0c;为用户提供便捷、智能的解梦服务。无论你是对梦境充满好奇&#xff0c;还是想从梦境中获取一些启示&#xff0c;这款插件都…

Git命令行入门

诸神缄默不语-个人CSDN博文目录 之前写过一篇VSCode Git的博文&#xff1a;VSCode上的Git使用手记&#xff08;持续更新ing…&#xff09; 现在随着开发经历增加&#xff0c;感觉用到命令行之类复杂功能的机会越来越多了&#xff0c;所以我专门再写一篇Git命令行的文章。 G…

【时时三省】(C语言基础)用N-S流程图表示算法

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 N-S流程图 既然用基本结构的顺序组合可以表示任何复杂的算法结构&#xff0c;那么&#xff0c;基本结构之间的流程线就是多余的了。1973年&#xff0c;美国学者I.Nassi和B .Shneiderman提出…

单元测试junit5

一、idea 安装自动化生成插件jcode5 安装可能不成功&#xff0c;尝试多次安装&#xff1b; 安装成功后&#xff0c;重启idea&#xff0c;再次确认安装是否成功&#xff1b; 二、在需要生成单元测试代码的模块的pom中引入依赖 ......<parent><groupId>org.springf…

Matlab写入点云数据到Rosbag

最近有需要读取一个点云并做处理后&#xff0c;重新写回rosbag。网上有很多读取的教程&#xff0c;但没有写入。自己写入时也遇到了很多麻烦&#xff0c;踩了一堆坑进行记录。 1. rosbag中一个lidar的msg有哪些信息&#xff1f; 通过如下代码&#xff0c;先读取一个rosbag的l…

c++标准io与线程,互斥锁

封装一个 File 类&#xff0c; 用有私有成员 File* fp 实现以下功能 File f "文件名" 要求打开该文件 f.write(string str) 要求将str数据写入文件中 string str f.read(int size) 从文件中读取最多size个字节&#xff0c; 并将读取到的数据返回 析构函数 #…

springboot-ffmpeg-m3u8-convertor nplayer视频播放弹幕效果

学习链接 ffmpeg-cli-wrapper - 内部封装了操作ffmpeg命令的java类库&#xff0c;它提供了一些类和方法&#xff0c;可以方便地构建和执行 ffmpeg 命令&#xff0c;而不需要直接操作字符串或进程。并且支持异步执行和进度监听 springboot-ffmpeg-m3u8-convertor - gitee代码 …

在做题中学习(90):螺旋矩阵II

解法&#xff1a;模拟 思路&#xff1a;创建相同大小的一个二维数组&#xff08;矩阵&#xff09;&#xff0c;用变量标记原矩阵的行数和列数&#xff0c;每次遍历完一行或一列&#xff0c;相应行/列数--&#xff0c;进行对应位置的赋值即可。此题是正方形矩阵&#xff0c;因此…