Vue:纯前端实现文件拖拽上传

news2025/1/15 16:37:49

先看一下拖拽相关的事件:dragoverdragenter dropdragleave

  • dragover事件:当被拖动的元素在一个可放置目标上方时,该事件会被触发。
    通常,我们会使用event.preventDefault()方法来取消浏览器默认的拖放行为,以便可以自定义拖拽行为。这个事件在拖拽过程中会持续触发,可以用于实现一些特殊的样式效果,如显示拖拽目标的悬浮效果。

  • drop事件:当拖动的元素被释放时,该事件会被触发。
    drop事件中,可以获取拖放的数据,并进行相应的处理。通过event.dataTransfer对象可以获得拖放相关的数据,包括被拖动的文件列表或其他自定义数据。我们可以在drop事件的处理函数中执行文件上传、移动元素等操作。
    注意,drop和dragover必须一起使用,不然drop无法被触发

  • dragenter事件:当被拖动的元素进入一个可放置目标时,该事件会被触发。
    这个事件通常与dragover事件一起使用,用于改变可放置目标的样式或状态,以向用户展示目标元素的拖放状态。

  • dragleave事件:当被拖动的元素离开一个可放置目标时,该事件会被触发。
    dragenter事件相似,这个事件也常常和dragover事件一起使用,用于恢复目标元素的样式或状态,以向用户展示拖放状态的变化。

具体实现:

<template>
  <div
    class="content"
    :class="{ 'drag-enter': dragEnter }"
    @dragover="handleDragOver"
    @dragenter="handleDragEnter"
    @dragleave="handleDragLeave"
    @drop="handleFileDrop"
  >
    <div v-if="!fileContent">将文件拖拽到这里显示</div>
    <p v-else>{{ fileContent }}</p>
  </div>
</template>

<script lang="ts" setup>
import { ref } from "vue";

const dragEnter = ref(false);
const fileContent = ref("");

// 被拖动的元素进入可放置目标时
const handleDragEnter = (e: DragEvent) => {
  dragEnter.value = true;
  e.preventDefault();
};

// 被拖动的元素在可放置目标上方时
const handleDragOver = (e: DragEvent) => {
  dragEnter.value = true;
  e.preventDefault();
};

// 被拖动的元素离开可放置目标时
const handleDragLeave = (e: DragEvent) => {
  dragEnter.value = false;
  e.preventDefault();
};

// 释放被拖动的元素
const handleFileDrop = (e: DragEvent) => {
  dragEnter.value = false;
  e.preventDefault();
  // 获取上传的文件,files是一个数组,可能同时存在一次拖拽多个文件的情况
  const files = e.dataTransfer?.files as FileList;
  // 此处只处理第一个上传的文件,file包含了上传的文件大小、类型、名称等信息
  const file = files[0];
  //  限制文件大小
  if (file.size / 1024 / 1024 > 10) {
    console.log("文件不能大于10M。");
    return;
  }
  // 限制文件类型
  if (!["text/plain", "application/json"].includes(file.type)) {
    console.log("仅支持txt、 json文件。");
    return;
  }
  // 定义一个文件读取器,读取文件内容
  let reader = new FileReader();
  reader.readAsText(file, "UTF-8");
  reader.onload = (e: ProgressEvent<FileReader>) => {
    fileContent.value = e.target?.result;
  };
};
</script>

<style scoped>
.content {
  width: 400px;
  height: 400px;
  overflow: auto;
  border: 1px solid #dcdfe6;
}
.empty-tips {
  margin: 0 auto;
}
.drag-enter {
  border: 1px solid #45a3ff;
}
</style>

页面展示:
在这里插入图片描述
实现其实很简单,主要就是掌握拖拽相关的几个事件。

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

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

相关文章

赛事通知丨2024年(第12届)“泰迪杯”挑战赛即将开始

2024年&#xff08;第12届&#xff09;“泰迪杯”数据挖掘挑战赛将于3月8日开放报名。“泰迪杯”数据挖掘挑战赛始创于2013年&#xff0c;迄今已经连续举办了12年。累计参赛高校千余所&#xff0c;累计参赛人数逾10万人&#xff0c;全国各省份均有参加。大赛的开展始终秉持推动…

局域网管理工具

每个组织的业务运营方法都是独一无二的&#xff0c;其网络基础设施也是如此&#xff0c;由于随着超融合基础设施等新计算技术的发展&#xff0c;局域网变得越来越复杂&#xff0c;因此局域网管理也应该如此&#xff0c;组织需要量身定制的局域网管理解决方案&#xff0c;这些解…

QT6.6 android开发环境搭建

一.目标 本文目的为实现在QT6.6下搭建android开发环境&#xff0c;可以实现QT6.6开发的QT程序&#xff08;widget及qml工程&#xff09;部署到android设备中。 二.环境安装 1.QT6.6环境安装 &#xff08;1&#xff09;在线安装器下载&#xff1a; https://download.qt.io/a…

手动更新服务器node新版本

1.安装nodejs下载到本地 2.下载后放到服务器上的指定目录中。例如/usr/local/src/node 3.执行tar -xvf node-v20.10.0-linux-x64.tar.xz解压 4.执行一下命令配置软连接 -f是如果文件存在就覆盖 # 将node源文件映射到usr/bin下的node文件 ln -fs /usr/local/src/node/node-…

10G Ethernet Subsystem 基于K7芯片的UDP通讯

此文章只用于教程开发笔记&#xff0c;不做过多的废话介绍。 IP核的建立 此选项不进行共享时钟逻辑。优点接口少好操作&#xff0c;缺点只可以建立一个IP核。&#xff08;我有一篇文章介绍了如何进行多个核互联&#xff09;传送门&#xff1a;FPGA光纤Aurora_8B_10B_fpga auro…

实现vue elmentUI图片本地上传

实现思路 后端代码 //上传头像PostMapping("/uplaod")public String upload(MultipartFile file) { // System.out.println(file"图片上次");//图片校验if (file.isEmpty()) {return "图片上传失败";}//可以自己加一点校验 例如上传的是不…

HBase 的安装与部署

目录 1 启动 zookeeper2 启动 Hadoop3 HBase 的安装与部署4 HBase 高可用 1 启动 zookeeper [huweihadoop101 ~]$ bin/zk_cluster.sh start2 启动 Hadoop [huweihadoop101 ~]$ bin/hdp_cluster.sh start3 HBase 的安装与部署 &#xff08;1&#xff09;将 hbase-2.0.5-bin.tar.…

加速大模型落地:火山引擎向量数据库的实践应用

近两年随着大模型技术的快速发展&#xff0c;图片、视频、自然语言等多模态、非结构化数据的查找需求变大&#xff0c;非结构化数据的量级也远大于结构化数据&#xff0c;传统数据库已经无法满足如此多样化数据的处理需求。向量数据库以其海量的数据存储规模、高效的计算查询能…

修改MonkeyDev默认配置适配Xcode15

上一篇文章介绍了升级Xcode15后,适配MonkeyDev的一些操作,具体操作可以查看:Xcode 15 适配 MonkeyDev。 但是每次新建项目都要去修改那些配置,浪费时间和精力,这篇文章主要介绍如何修改MonkeyDev的默认配置,做到一次修改永久生效。 MonkeyDev的默认安装路径是在/opt/Mo…

智能驾驶规划控制理论学习07-规划算法整体框架

一、解耦合策略 1、路径-速度解耦策略概述 路径-速度解耦指的是将车辆的运动分成路径规划和速度规划两部分&#xff0c;对两个部分分别进行研究。 路径规划&#xff1a; 假设环境是“静态的”&#xff0c;将障碍物投射到参考路径上&#xff0c;并规划一条避开它们的路径&…

004-执行上下文事件循环

执行上下文&事件循环 1、执行上下文2、执行上下文类型3、执行上下文的生命周期4、示例说明5、事件循环机制6、宏任务7、微任务8、同步任务、宏任务、微任务9、代码执行顺序 - 示例 &#x1f4a1; Tips&#xff1a;用于说明 浏览器 对 JavaScript 执行顺序&#xff0c;涉及知…

web学习笔记(二十七)PC端网页特效

目录 1.元素偏移量offset 1.1什么是offset 1.2offset系列常用属性 1.3offset总结 1.4offset 与 style 区别 2.元素可视区client 3.元素滚动scroll 4.总结 4.1三大系列总结 4.2 mouseenter 和mouseover的区别 1.元素偏移量offset 1.1什么是offset offset就是偏移量…

TikTok小店如何批量生成/上传产品视频?

有许多Shopee卖家都会遇到这样的问题&#xff1a;明明产品标题、描述优化了&#xff0c;产品主图也认真做了&#xff0c;但是自己的Shopee店铺还是没转化! 可能是忽略了产品视频。 在Shopee官方的交流沙龙中&#xff0c;Shopee官方讲师提及&#xff1a;“有视频的产品比没有视…

Linux(Centos7)安装Docker 教程

目录 1&#xff0c;卸载旧版本2&#xff0c;安装docker软件包3,设置镜像仓库地址4,安装最新版Docker Engine容器5&#xff0c;启动Docker 要安装Docker Engine&#xff0c;您需要CentOS 7或8的维护版本。不支持或未测试存档版本。 1&#xff0c;卸载旧版本 sudo yum remove do…

2023 最新 IntelliJ IDEA 2023.3 详细配置步骤演示:新入职如何快速配置 IntelliJ IDEA?

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

基于UDP实现的网络聊天室

服务器&#xff1a; #include <myhead.h> struct msg {char type;char name[20];char text[1024]; };int main(int argc, const char *argv[]) {if(argc!3){printf("input error\n");printf("./a.out IP地址 端口号\n");return -1;}//1、创建用于通…

企业级Avatar道具解决方案

美摄科技&#xff0c;作为业界领先的多媒体解决方案提供商&#xff0c;近日推出了一款革命性的Avatar道具解决方案&#xff0c;旨在帮助企业打造独特且高度个性化的数字形象&#xff0c;从而提升企业品牌的吸引力和影响力。 这款解决方案的核心在于其先进的单摄像头Avatar生成…

MYSQL使用mysqldump备份、复原数据库

参考 添加链接描述 1. 备份数据库 C:\Windows\system32>mysqldump -uroot -p test student>C:\student.sql Enter password: ****2. 备份多个数据库 mysqldump -u root -p --databases test mysql>C:\testandmysql.sql3. 备份所有数据库 mysqldump -u root -p -…

R实现热图与网络图组合并显示显著性

大家好&#xff0c;我是带我去滑雪&#xff01; 热图和网络图分别展示了数据的不同方面。热图可用于显示变量之间的相关性或模式&#xff0c;而网络图则可用于显示节点之间的连接关系。通过将它们组合在一起&#xff0c;可以更全面地展示数据之间的关系和结构。下面开始代码实战…

数据结构界的终极幻神----树

目录 一.数的概念和分类 种类 二.重点概念 哈希树: 二叉树的线索化 什么是线索化 为什么要线索化 特殊的查找树 完全二叉树 三.手撕完全二叉树(堆) 重点讲解 向上搜索算法 向下搜索算法 一.数的概念和分类 树&#xff08;tree&#xff09;是包含 n(n≥0) [2] 个节…