当前位置: 首页 > article >正文

uniapp中的uni-file-picker组件上传多张图片到服务器

由于在uniapp官方文档中的uni-file-picker组件可实现图片上传功能,默认的是上传到自带的服务,所以我们要修改成自己的服务器

1. 添加  :auto-upload="false"   加上这个取消自动上传

<uni-file-picker v-model="jobAddUpdateForm.imageList" :auto-upload="false"  fileMediatype="image" limit="9" :image-styles="imageStyles" @select="successData">
</uni-file-picker>

2.vue2 封装mixin (vue3 可以封装 hooks) 方便后期调用

import config from '@/config';
import {
	getToken
} from '@/utils/auth'; // 导入获取 token 的函数  

// 上传图片的异步函数  
const uploadImg = async function(tempFilePaths) {
	const baseUrl = config.baseUrl; // 基础 URL 从配置中获取  
	const token = getToken(); // 使用 getToken 函数获取 token  
	const successfulUploads = []; // 数组用于记录所有成功上传的文件路径  

	if (!tempFilePaths.length) return []; // 如果没有选择图片就退出,返回空数组  

	// 遍历选择的图片路径  
	for (const path of tempFilePaths) {
		try {
			// 调用接口上传每一张图片  
			const [err, {
				data
			}] = await uni.uploadFile({
				url: `${baseUrl}/common/upload`, // 自己的后台地址  
				filePath: path,
				name: 'file',
				header: { // 添加请求头  
					'Authorization': `Bearer ${token}`, // 假设你使用的是 Bearer 认证  
					// 可以添加其他需要的请求头  
				},
			});

			// 处理错误情况  
			if (err) {
				console.error('上传错误:', err);
				continue; // 如果上传出错,继续上传下一张图片  
			}
			  // 把返回的数据转为对象格式  
			const dataObj = JSON.parse(data); 
			console.log(dataObj)
			// 将每个上传成功的文件路径添加到数组中  
			successfulUploads.push(dataObj); // 假设 dataObj.data 是上传后的文件路径  
		} catch (error) {
			console.error('处理上传时发生错误:', error);
			continue; // 捕获上传错误并继续  
		}
	}

	// 返回所有成功上传的文件路径  
	return successfulUploads;
};

// 导出 uploadImg 函数  
export default uploadImg;

需要注意的是 请求的url ,需要换成自己的接口地址

3. 在使用的地方引入就可以了

import uploadImg from '@/mixin/imageData.js';



// 上传接口
	async successData(e){
		const res = await uploadImg.call(this, e.tempFilePaths)
		console.log(res)
}

就可以返回上传的信息了

参考:uniapp中的uni-file-picker组件上传多张图片到服务器,可添加,预览,删除图片_uni-file-picker详细使用教学-CSDN博客


http://www.kler.cn/a/442867.html

相关文章:

  • 【优选算法篇】:深入浅出位运算--性能优化的利器
  • antd-design-vue1.7.8浏览器中使用
  • Autoencoder(李宏毅)机器学习 2023 Spring HW8 (Boss Baseline)
  • C++ Qt 模板函数和函数重载
  • 1.Nuxt学习 搭建项目 渲染页面基本操作
  • RabbitMQ的核心组件有哪些?
  • 【操作系统】每日 3 题(七十一)
  • 深度学习物体检测之YOLOV5源码解读
  • 为markdown导出的pdf添加页眉页脚
  • 分享一次接口性能摸底测试过程
  • qt 鼠标点击事件
  • Servlet学习中遇到的一些问题及解决
  • 从零开始学习 sg200x 多核开发之 sophpi 编译生成 fip.bin 流程梳理
  • docker修改容器网络
  • Cobalt Strike 4.8 用户指南-第十四节 Aggressor 脚本
  • 强化学习Q-learning及其在机器人路径规划系统中的应用研究,matlab代码
  • ubuntu禁用内核更新
  • 【Java入门指南 Day15:Java网络编程】
  • C# 如何使用多线程
  • 深入理解数据库 JOIN 操作
  • 【Tomcat】第一站:理解tomcat与Socket
  • 【面试问题】JIT 是什么?和 JVM 什么关系?
  • IDEA下加载音频文件操作