项目中图片放大镜效果(Vue3的写法)

2023-11-21 10:30

本文主要是介绍项目中图片放大镜效果(Vue3的写法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现效果

代码落地

<template><div class="goods-image"><!-- 大图容器 --><divclass="large":style="[{backgroundImage: `url(${imageList[curId]})`,backgroundPositionX: position.backgroundPositionX,backgroundPositionY: position.backgroundPositionY,},]"v-if="isShow"></div><div class="middle" ref="target"><img :src="imageList[curId]" alt="" /><!-- 蒙层容器 --><div class="layer" :style="{ left: left + 'px', top: top + 'px' }" v-if="isShow"></div></div><ul class="small"><liv-for="(img, i) in imageList":key="i"@mouseenter="curId = i":class="{ active: curId === i }"><img :src="img" alt="" /></li></ul></div>
</template><script>
import { reactive, ref, watch } from 'vue'
import { useMouseInElement } from '@vueuse/core'
export default {name: 'GoodsImage',props: {imageList: {type: Array,default: () => {return []}}},setup () {const curId = ref(0)const target = ref(null)// elementX: 鼠标距离左侧的偏移值// elementY:表表距离顶部的偏移值// isOutside: 是否在容器外部  外部true  内部 falseconst { elementX, elementY, isOutside } = useMouseInElement(target)const left = ref(0) // 滑块距离左侧的距离const top = ref(0) // 滑块距离顶部的距离const isShow = ref(false) // 显示大图和蒙层图的显示和隐藏const position = reactive({ // 大图显示的位置,默认是0backgroundPositionX: 0,backgroundPositionY: 0})watch(// 监听的对象[elementX, elementY, isOutside],() => {if (elementX.value < 100) {// 左侧最小距离left.value = 0}if (elementX.value > 300) {left.value = 200}if (elementX.value > 100 && elementX.value < 300) {left.value = elementX.value - 100}if (elementY.value < 100) {// 左侧最小距离top.value = 0}if (elementY.value > 300) {top.value = 200}if (elementY.value > 100 && elementY.value < 300) {top.value = elementY.value - 100}// 控制背景图移动// 1. 蒙层移动的方向和大图背景移动的方向是相反的// 2. 蒙层和大图由于面积大小是1:2的 蒙层每移动一个像素  大图移动俩个像素// backgrondPosition:x,y;position.backgroundPositionX = -left.value * 2 + 'px'position.backgroundPositionY = -top.value * 2 + 'px'// 当isOutside的值发生变化的时候,立刻取反赋值给isShow// isOutside: 是否在容器外部  外部true  内部 falseisShow.value = !isOutside.value},{})return {curId,target,left,top,position,isShow}}
}
</script>

 

这篇关于项目中图片放大镜效果(Vue3的写法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/401757

相关文章

javafx 如何将项目打包为 Windows 的可执行文件exe

《javafx如何将项目打包为Windows的可执行文件exe》文章介绍了三种将JavaFX项目打包为.exe文件的方法:方法1使用jpackage(适用于JDK14及以上版本),方法2使用La... 目录方法 1:使用 jpackage(适用于 JDK 14 及更高版本)方法 2:使用 Launch4j(

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

使用Python实现生命之轮Wheel of life效果

《使用Python实现生命之轮Wheeloflife效果》生命之轮Wheeloflife这一概念最初由SuccessMotivation®Institute,Inc.的创始人PaulJ.Meyer... 最近看一个生命之轮的视频,让我们珍惜时间,因为一生是有限的。使用python创建生命倒计时图表,珍惜时间

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.