uniapp 实现上传文件的功能

上传单个文件

html 复制代码
<script setup>
	const handleUploadClick = () => {
		console.log("上传文件")
		uni.chooseImage({
			success: (chooseImageRes) => {
				const tempFilePaths = chooseImageRes.tempFilePaths;
				console.log("用户选择的图片:", tempFilePaths)
				uni.uploadFile({
					url: 'http://192.168.234.138:8889/upload', 
					filePath: tempFilePaths[0],
					name: 'file',
					success: (uploadFileRes) => {
						console.log("上传文件成功", uploadFileRes.data);
					}
				});
			}
		});
	}
</script>
<template>
	<view>
		<view @click="handleUploadClick" class="button">
			上传文件
		</view>
	</view>
</template>

<style scoped>
	.button {
		display: inline-block;
		background-color: aqua;
		padding: 10rpx 20rpx;
		border-radius: 5%;
	}
</style>

上传多个文件

上传多个文件的功能有个细节需要注意,那就是files不能直接使用读取到的文件列表,官方文档给出如下解释。

按照官方文档的要求,最终成功的代码如下:

html 复制代码
<script setup>
	const handleUploadClick = () => {
		console.log("上传文件")
		uni.chooseImage({
			success: (chooseImageRes) => {
				const tempFilePaths = chooseImageRes.tempFilePaths;
				console.log("用户选择的图片:", tempFilePaths)
				let files = []
				for (let filePath of tempFilePaths){
					console.log("filePath", filePath)
					files.push({
						name: "file",
						uri: filePath,
					})
				}
				uni.uploadFile({
					url: 'http://192.168.234.138:8889/uploads', 
					files: files,
					success: (uploadFileRes) => {
						console.log("上传文件成功", uploadFileRes.data);
					}
				});
			}
		});
	}
</script>
<template>
	<view>
		<view @click="handleUploadClick" class="button">
			上传文件
		</view>
	</view>
</template>

<style scoped>
	.button {
		display: inline-block;
		background-color: aqua;
		padding: 10rpx 20rpx;
		border-radius: 5%;
	}
</style>
相关推荐
大柏怎么被偷了10 分钟前
【Qt】关于QMenuBar创建方式的讨论
开发语言·c++·qt
Zevalin爱灰灰11 分钟前
Matlab simulink建模与仿真 第六章(逻辑运算、位运算库)
开发语言·matlab
大福是小强13 分钟前
016_Save_the_picture_in_Matlab中保存图片
开发语言·matlab·导出·绘图·图片·出图
晚风相伴13 分钟前
C++八股文之语言基础篇
开发语言·c++
Jarrett_Zheng22 分钟前
C#——类与结构
开发语言·c#
Night0322 分钟前
数据结构A1
开发语言·数据结构·c++·学习·算法·c#
FUXI_Willard23 分钟前
MATLAB绘图基础2:MATLAB数据结构
开发语言·数据结构·matlab
A_ugust__28 分钟前
uniapp小程序实现横屏手写签名
小程序·uni-app
是店小二呀28 分钟前
【C++】C++ STL 探索:String的使用与理解
开发语言·c++·后端
2301_7969821429 分钟前
怎样通过bs4找出程序中 标签<div class=“List2“>中所有的<li>的内容?
java·前端·javascript