【uniapp】如何实现拖动文件直接上传

news2025/1/13 8:05:52

做uniapp项目发布H5有个后台管理,用户说上传文件的体验需要改进,那个弹出选择文件对话框然后去填文件路径选择文件上传,感觉操作太麻烦,于是就有了这么一个需求,需要实现拖动文件直接上传的,这样效率和体验都比较好。

文章目录

  • 使用场景
  • 自定义组件
    • 脚本实现
    • 拖动文件
  • 使用例子
    • 使用组件
    • 拖动上传
  • 测试效果

使用场景

怎么实现呢,接下来研究自己电脑的资源管理器拖动文件效果,如下图所示,实现步骤大致讲一下,请想象一下被使用场景,需要给被使用者创建一个自定义组件<my-drag-files>来用
在这里插入图片描述

自定义组件

然后,在自定义组件中加上一个子组件标签,为插槽<slot>,由将来使用者加入被监听的子组件,代码如下

<template>
	<view class="my-drag-files" id="my-drag-files">
		<slot></slot>
	</view>
</template>
<script>
	//...
</script>
<style lang="scss">
	.my-drag-files{
		height: 100%;
	}
</style>

脚本实现

实现自定义组件脚本,添加拖动文件监听,代码如下

export default {
		name:"my-drag-files",
		data() {
			return { };
		},
		mounted() {
			//添加监听
			let elem = document.getElementById('my-drag-files');
			elem.addEventListener('drop',this.ondrop,false);
			elem.addEventListener('dragleave',this.ondropprevent);
			elem.addEventListener('dragenter',this.ondropprevent);
			elem.addEventListener('dragover',this.ondropprevent);
			this.elem=elem;
		},
		// 销毁时
		beforeUnmount(){
			const { elem } = this;
			//移除监听
			elem.removeEventListener('drop',this.ondrop);
			elem.removeEventListener('dragleave',this.ondropprevent);
			elem.removeEventListener('dragenter',this.ondropprevent);
			elem.removeEventListener('dragover',this.ondropprevent);
		},
		methods:{
			//...
		}
	}

注意Vue开发版本,Vue2 用的是 beforeDestroy() ,Vue3用的beforeUnmount()

拖动文件

实现拖动事件方法ondrop(event),当拖动文件完成,会通过事件消息发出获取到的文件,交给将来使用者去实现

export default {
	name:"my-drag-files",
	//...
	methods:{
		ondrop(event){
			this.ondropprevent(event);
			this.$emit('drop',{
				detail:{ files:event.dataTransfer.files },
				currentTarget:{ dataset:{} }
			});
		},
		ondropprevent(event){				
			event.stopPropagation();
			event.preventDefault();
		}
	}
}

使用例子

使用组件

这样的自定义组件就算完成了,再看看将来使用者使用例子,在使用的自定义组件上需要添加一个监听事件方法ondrop,代码如下

<template>
	<view class="window-file-list">
		<my-drag-files @drop='ondrop'>
			<view class="column">
				<view class="padding table-tr">
					<!-- 列表头 -->
				</view>
				<scroll-view class="scroll-view expand" scroll-y="true">
					<view class="padding">
						<!-- 文件列表 -->
					</view>
				</scroll-view>
			</view>
		</my-drag-files>
	</view>
</template>
<script>
	//...
</script>
<style lang="scss">
	//...
</style>

拖动上传

脚本中,添加监听事件方法ondrop(e),在里面实现文件上传就好

export default{
	//...
	methods:{
		ondrop(e){
			// console.log('ondrop',e)
			const { files } = e.detail;
			//...
			uni.uploadFile({
				url:'...',
				//filePath:this.getTempFilePath(file[0]),
				files,
				success:(res)=>{
					console.log('uploadFile',res);
				}
			});
		},
		getTempFilePath(file){
			let path;
			if(window.createObjectURL) path=window.createObjectURL(file);
			else if(window.webkitURL) path=window.webkitURL.createObjectURL(file);
			else if(window.URL) path=window.URL.createObjectURL(file);
			else console.error('getTempFilePath has error');
			return path;
		}
	}
}

其中添加的方法getTempFilePath(file)就是获取文件的临时文件路径的,如有需要,会用得上

测试效果

到此结束,试试看效果,代码写得没问题的话,从电脑桌面拖动文件到文件列表中试试,就会直接上传了。
请添加图片描述

注意,此项目实现的拖动文件上传功能只能在H5上用哦~

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

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

相关文章

九、动态组件与插槽

一、动态组件 1.1、什么是动态组件 动态组件指的是动态切换组件的显示与隐藏。 1.2、如何实现动态组件渲染 vue提供了一个内置的<component>组件&#xff0c;专门用来实现动态组件的渲染。示例代码如下&#xff1a; data() {// 1. 当前要渲染的组件名称return {comN…

学习笔记:混沌工程

个人理解&#xff1a; 混沌工程&#xff0c;chaos engineering&#xff0c;找出系统中的脆弱环节的方法学 混沌工程是软件测试和质量保证的一种方法&#xff0c;在黑客入侵之前或系统故障之前使用它来识别漏洞&#xff0c;由于混沌工程测试而做出的改变增加了人们对系统的信心。…

SpringBoot @SessionScope注解和Session的用法解释

参考资料 JSESSIONID是什么SessionScope 解决了不同session下如何生成不同服务实例 目录一. 前期准备二. 被SessionScope作用的类三. 使用被SessionScope作用类的Service四. 效果4.1 用Edge浏览器进入页面4.2 然后用Edge浏览器进入页面4.3 若将CacheHolder类上的SessionScope注…

nginx部署next项目访问日志去重小技巧,next项目资源不计入日志,网站日志统计去除资源请求

next项目访问日志去重小技巧需求提出具体解决方案配置代码需求提出 之前在跟SEO做网站日志分析的时候受到了一部分资源请求数据的影响&#xff0c;统计出来的ip访问次数远远大于实际值&#xff0c;从日志中或者网站控制台看到每个页面都会发送十几个请求&#xff0c;而这些请求…

Qt中使用QWebEngine加载百度离线地图,在特定地点加载个圣诞树

一、前言 2022年圣诞节到来啦&#xff0c;很高兴这次我们又能一起度过~ 遇上圣诞节&#xff0c;正好最近研究了QT中加载百度离线地图&#xff0c;用百度地图API加载个圣诞树&#xff08;主要我想要那个圣诞节特制勋章&#xff09;。 二、创意名 在百度离线地图加载个圣诞树。…

演化博弈、复制动态方程与仿真

本文只整理和总结一下我的理解&#xff0c;文末列出了可供参考的更详细完整的资料。建议先看参考资料[1]&#xff08;博弈论公开课&#xff09;的博弈论课程&#xff0c;可以直接从第11讲开始看。   参考链接[2]是关于演化博弈非常经典的一本书。   参考链接[5]涵盖内容比较…

CSDN文章质量检测系统

想知道你的文章在CSDN中质量如何吗&#xff1f; 你想知道你的CSDN文章到底写得怎么样吗&#xff1f; 你想要获得一个你的系统的CSDN文章评分吗&#xff1f; CSDN质量分数帮你解决这个问题&#xff0c;网址如下&#xff1a; https://www.csdn.net/qc 界面在如下&#xff0c;如果…

XGBoost模型的python实现

文章目录函数介绍实例二分类问题多分类问题作者&#xff1a;李雪茸函数介绍 实现 XGBoost 分类算法使用的是 xgboost 库的 XGBClassifier&#xff0c;具体参数如下&#xff1a; 1、max_depth&#xff1a;给定树的深度&#xff0c;默认为3 2、learning_rate&#xff1a;每一步…

SpringBoot整合TKMyBatis实现增删改查

文章目录什么是TKMybatis&#xff1f;SpringBoot整合TKMybatis实体类注解TKMapper接口如何使用基本增删改操作批量查询和删除批量添加自定义查询条件ExampleExample 条件设置Example 使用什么是TKMybatis&#xff1f; TKMybatis 是基于Mybatis 框架开发的一个工具&#xff0c;…

[4]MQTT协议基础--下

1.QoS服务质量等级 MQTT服务质量(Quality of Service 缩写 QoS)正是用于告知物联网系统&#xff0c;哪些信息是重要信息需要准确无误的传输&#xff0c;而哪些信息不那么重要&#xff0c;即使丢失也没有问题。 MQTT协议有三种服务质量级别&#xff1a; QoS 0 – 最多发一次…

公司jmeter分享

一、数据库压测组件功能说明 1.JDBC Connection Configuration:jdbc连接配置(一个测试计划可以有多个 JDBC Connection) 2.Variable Name for created pool: 创建池的变量名 连接绑定的变量名,JMeter可以使用多个连接,每个连接绑定到不同的变量;通过引用不同的绑定变量…

安全防范语音通知实现方案

语音通知作为一种强提醒的信息通知方式&#xff0c;非常适合使用在安全防范语音通知场景中&#xff0c;可以有效避免用户错过重要信息。那安全防范语音通知怎么实现&#xff1f;这里互亿无线小编为大家做个详细介绍&#xff1a; 一、如何发送安全防范语音通知信息 互亿无线语…

本地事务、分布式事务、CAP 定理与 BASE 理论、分布式事务几种方案、Linux 安装 Seata、Seata的使用-56

一&#xff1a;本地事务 1.1 事务的基本性质 1.数据库事务的几个特性&#xff1a;原子性(Atomicity )、一致性( Consistency )、隔离性或独立性( Isolation)和持久性(Durabilily)&#xff0c;简称就是 ACID&#xff1b; 原子性&#xff1a;一系列的操作整体不可拆分&#xf…

LVGL学习笔记8 - 字体

目录 1. 修改默认字体 2. 修改字体 3. 特殊字体 3.1 SUBPX字体 3.2 28像素压缩字体 3.3 16像素希伯来语/阿拉伯语/Perisan字母 3.4 16像素中文字体 3.5 8像素Ascii字体 3.6 16像素Ascii字体 3.7 内置图标 4. 超大字体 5. 编码方式 6. 添加字体 6.1 在线字体转换器 …

【微服务笔记01】微服务组件之Eureka注册中心的介绍及其基础环境的搭建

这篇文章&#xff0c;主要介绍微服务中的注册中心Eureka及其基础环境的搭建【源代码地址】。 目录 一、Eureka注册中心 1.1、什么是注册中心 1.2、注册中心原理 二、搭建Eureka注册中心环境 2.1、创建父工程&#xff0c;引入微服务依赖 2.2、创建Eureka服务端工程 &…

全球公开的DEM数据产品

1 简介 全球公开版地形数据包括&#xff1a;GTOPO30-DEM、ASTER-GDEM、SRTM90、ALOS-AW3D30等&#xff0c;其他的诸如World DEM及ALOS-AW3D (5m分辨率&#xff09;等全球地形数据不能免费获得。 SRTM&#xff1a;由NASA 及国家地理空间情报局NGA采用2000年2月发射的“奋进号”…

word文件损坏打不开如何修复?文件丢失怎么办?

我们日常办公中&#xff0c;经常用到Word文档。但是有时会遇到word文件损坏、无法打开的情况。这时该怎么办&#xff1f;接着往下看&#xff0c;小编在这里就给大家带来Word文件修复的方法&#xff0c;以及Word文件丢失如何恢复的方法&#xff01; 一、Word文件损坏怎么办 部分…

【vsan数据恢复】磁盘离线导致分布式存储瘫痪的数据恢复案例

vsan数据恢复环境&#xff1a; 一组4台服务器搭建vsan集群&#xff1b; 每台服务器配置有2组分别由6块硬盘组成的磁盘阵列&#xff0c;上层是虚拟机文件。 vsan故障&#xff1a; 在运行过程中&#xff0c;某一个节点的一块硬盘离线&#xff0c;vsan安全机制启动&#xff0c;开始…

梦想云图Node.JS服务 ( 最近更新时间:2022-12-30 10:04:50 )

说明 后台提供梦想Node.JS服务&#xff0c;方便调用控件后台功能&#xff0c;Windows服务程序所在目录:Bin\MxDrawServer\Windows&#xff0c;Linux服务程序所在目录:Bin\Linux\MxDrawServer 梦想云图Node.JS服务 &#xff08; 最近更新时间&#xff1a;2022-12-30 10:04:50 …

第三个脚本——时间加速and视频倍速

目录 本文主要内容 granr属性介绍 run-at属性 时间加速原理 视频倍速原理 完整示例 本文主要内容 介绍grant属性&#xff0c;run-at属性以及时间加速&#xff0c;视频倍速原理 granr属性介绍 相关函数四个&#xff1a; GM_setValue GM_getValue GM_listValues GM_del…