vue3+ts实现图片预览功能

首先,需要创建一个Vue组件,用于显示图片和预览图。

<template><div><img :src="imageSrc" @mouseover="showPreview" @mouseout="hidePreview" /><div v-if="previewVisible" class="preview-container"><img :src="previewSrc" class="preview-image" /></div></div>
</template><script lang="ts">
import { ref } from 'vue';export default {props: {imageSrc: {type: String,required: true,},previewSrc: {type: String,required: true,},},setup(props) {const previewVisible = ref(false);const showPreview = () => {previewVisible.value = true;};const hidePreview = () => {previewVisible.value = false;};return {previewVisible,showPreview,hidePreview,};},
};
</script><style scoped>
.preview-container {position: absolute;top: 0;left: 0;z-index: 999;
}.preview-image {width: 200px;height: 200px;
}
</style>

在父组件中使用这个图片预览组件。

<template><div><ImagePreviewv-for="image in images":key="image.id":imageSrc="image.src":previewSrc="image.previewSrc"/></div>
</template><script lang="ts">
import { defineComponent } from 'vue';
import ImagePreview from './ImagePreview.vue';export default defineComponent({components: {ImagePreview,},data() {return {images: [{id: 1,src: 'path/to/image.jpg',previewSrc: 'path/to/preview.jpg',},// 添加更多图片...],};},
});
</script>

在父组件中,通过遍历images数组,将每个图片的路径传递给ImagePreview组件的imageSrcpreviewSrc属性。

当用户将鼠标悬停在图片上时,@mouseover事件会触发showPreview方法,将previewVisible的值设为true,从而显示预览图。

当用户将鼠标移出图片时,@mouseout事件会触发hidePreview方法,将previewVisible的值设为false,从而隐藏预览图。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【计算机考研】学硕还是专硕?

这里面没有什么更好的选择&#xff0c;大家都知道专硕录取人数多&#xff0c;学硕录取人数上&#xff0c;博弈一直存在 单就考研的难度上来说&#xff0c;专硕的难度确实要比学说低很多的&#xff0c;同样的专业课的情况下&#xff0c;专硕的考研数学考的是数学二和英语二&…

rk3568 gamc0 控制器寄存器配置不了导致连接不上phy

系统启动 GMAC 的驱动开机 log 上出现打印&#xff1a;No PHY found 或者 Cannot attach to PHY。查阅rk 官方gmac 配置指导手册出现改问题的原因可能如下&#xff1a; 但反复检查硬件和软件发现都没问题。看内核启动日志发现gamc0 在启动过程中读取gmac0 的版本id是读取不到&a…

P2440 木材加工

题目背景 要保护环境 题目描述 木材厂有 &#xfffd;n 根原木&#xff0c;现在想把这些木头切割成 &#xfffd;k 段长度均为 &#xfffd;l 的小段木头&#xff08;木头有可能有剩余&#xff09;。 当然&#xff0c;我们希望得到的小段木头越长越好&#xff0c;请求出 &a…

表格自定义音频播放组件

1.在使用的地方调用 <Audiosvue ref"audio" class"audio-box" :audioFile"item.cont"></Audiosvue> 2.引入组件 import Audiosvue from "/components/audio"; 3.组件 <template><div><div style"d…

优化Vue项目中 WebStorm:2023.3 对 CSS 和 HTML 的默认注释

前言 WebStorm是一种基于JetBrains IntelliJ平台的集成开发环境&#xff08;IDE&#xff09;&#xff0c;专门用于Web开发。它支持JavaScript、HTML和CSS等语言&#xff0c;并提供了丰富的功能和工具&#xff0c;以提高开发人员的效率。但是&#xff0c;在开发Vue项目中发现&a…

(科目三)计算机操作系统

1、操作系统的基本概念及功能 1.1概念 一、操作系统的概念 操作系统是运行在裸机之上的&#xff0c;控制和管理计算机硬件和软件资源、合理组织计算机工作流程一级方便用户操作的程序集合。 操作系统由一套分层次的控制程序组成&#xff0c;是计算机硬件的一级扩充是软件系…

【爬虫逆向实战 逆向滑块 Python+Node】今天逆向的网站有点嘿嘿,还是仅供学习,别瞎搞

逆向日期&#xff1a;2024.03.01 使用工具&#xff1a;Node.js、Python 加密方法&#xff1a;AES标准算法 文章全程已做去敏处理&#xff01;&#xff01;&#xff01; 【需要做的可联系我】 AES解密处理&#xff08;直接解密即可&#xff09;&#xff08;crypto-js.js 标准算…

Java底层自学大纲_互联网安全设计篇

互联网安全设计专题_自学大纲所属类别学习主题建议课时&#xff08;h&#xff09; A 互联网安全架构平台设计001 如何防御XSS攻击与防止抓包篡改数据2.5 A 互联网安全架构平台设计002 spring security实现动态权限控制2.5 A 互联网安全架构平台设计003 spring security整合j…

基于RISC-V架构的通信DSP的设计以及在5G RedCap基带中的应用(六)-结论与展望

6 结论与展望 6.1 研究成果总结 基于RISC-V架构的向量指令集和通讯扩展指令集在5G Redcap基带处理器中的应用&#xff0c;可以有效提升处理器在处理大量数据时的性能以及满足特定应用需求的无线通讯能力。随着5G技术的发展&#xff0c;对于满足特定应用需求的行业&#xff0c;…

CentOS7 Mysql 忘记密码或临时密码进不去时怎么跳过密码进去然后再更改密码

CentOS7 Mysql 忘记密码或临时密码进不去时怎么跳过密码进去然后再更改密码 1、进文件 vi /etc/my.cnf2、加skip-grant-tables设置跳过密码 在[mysqld]下面加 skip-grant-tables3、mysql -u root -p直接回车无密码进去mysql mysql -u root -p3、先更新&#xff0c;不执行这…

实现unity场景切换

本文实现两个按键实现场景1和场景2之间的切换 ①首先在unity 3D中创建两个场景&#xff0c;分别为Scene1和Scene2 ②在Scene1中创建一个Button&#xff0c;修改txt内容为“To Scene2”&#xff0c;并在Buttons下创建一个空物体&#xff0c;用于挂载脚本。 脚本Trans Scene.…

操作系统x面试|进程与线程

1. 线程进程的区别 进程可以称为是资源分配的最小单元&#xff0c;而线程可以称为是处理器分配的最小单元。 资源包括内存空间。同时进程是一段代码的执行过程&#xff0c;这段代码需要多少的内存在代码确定时已经确定下来了。 处理器就是执行单元&#xff0c;一个进程可以拆解…

程序员的金三银四求职宝典

程序员的金三银四求职宝典 金三银四&#xff0c;即三月和四月&#xff0c;是程序员求职的黄金时期。在这个关键时期&#xff0c;求职者们需要做好充分的准备&#xff0c;以便在面试中脱颖而出。以下是一些建议&#xff0c;帮助程序员在金三银四期间更好地准备求职&#xff1a;…

【DAY06 软考中级备考笔记】数据结构:树

数据结构&#xff1a;树 3月1日 – 天气&#xff1a;晴 之前在B站看的视频讲的是在太过简单&#xff0c;弃了。现在换了新的视频继续&#xff0c;后续会重新看前面的视频补过来。https://www.bilibili.com/video/BV1pT4m1S7uH/ 1. 树的基本概念 需要注意的是&#xff1a; 并不是…

CentOS7使用yum安装MySQL8.0教程

CentOS7使用yum安装MySQL8.0 一、下载MySQL Yum下载仓库二、安装MySQL三、为MySQL运行提供相关的用户以及环境四、启动MySQL五、MySQL开机自启六、修改MySQL中root账户的密码 一、下载MySQL Yum下载仓库 MySQL下载地址&#xff1a;https://dev.mysql.com/downloads/ 首先进入下…

【前端面试题3】如何实现一个元素的水平垂直居中

以下是题目的布局代码&#xff1a; <div class"container"><div class"item" style"width: 100px; height: 100px; background: #999;">块状元素</div> </div><div class"container"><div class&qu…

Golang处理gRPC请求/响应元数据

前段时间实现内部gRPC框架时&#xff0c;为了实现在服务端拦截器中打印请求及响应的头部信息&#xff0c;便查阅了部分关于元数据的资料。因为中文网络上对于该领域的信息较少&#xff0c;于是在这做了一些简单的总结。 元数据 gRPC的元数据&#xff08;metadata&#xff09;…

Java通过Semaphore控制同一时间只有3个线程运行

怎么控制同一时间只有3个线程运行&#xff1f; 直接上代码 import java.util.Date; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Semaphore;public class SemaphoreThreadPoolExample {private static…

【网站项目】324企业人事信息管理系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

Windows下卸载JDK

操作步骤&#xff1a; 直接到windows程序卸载面板进行卸载 然后删除已配置的环境变量