多个Promise循环和 循环里面异步问题示例

javascript 复制代码
export function obsPost(data = []) {
	return new Promise(function(resolve, reject) {
		if (!data || data.tempFilePaths.length <= 0) {
			return reject('上传正确数据!')
		}
		let linshi_arr = [],
			true_arr = [],
			fileName = '',
			suffix = '',
			path = '',
			tempName = '';

		for (let i in data.tempFiles) {
			fileName = data.tempFiles[i].name //文件名字
			suffix = fileName.substring(fileName.lastIndexOf(".") + 1)
			tempName = data.tempFilePaths[i]
			tempName = tempName.substring(tempName.lastIndexOf("/") + 1)
			path = suffix + '/' + tempName + '-' + (Date.parse(new Date()) / 1000) + '.' + suffix
			linshi_arr.push(new Promise(function(resolve1, reject1) {
				(function(path1,resolve1, reject1){
					uni.common.post(
						uni.common.apiServer + 'yin', {
							type: 'get_obs_key', //获取有多少题
							path:path1
						},
						true,
						(res) => {
							if (res.code == 200) {
								uni.uploadFile({
										url: res.data.url, //用你自己的 bucket 名替换星号
										filePath: data.tempFilePaths[i],
										name: 'file',
										formData: {
											'key': path1,
											'AccessKeyId': res.data.Accesskeyid,
											'Policy': res.data.Policy,
											'x-obs-acl': 'public-read',
											'content-type': '',
											'Signature': res.data.Signature
										},
										success() {
											true_arr.push(path1)
											resolve1()
										},fail() {
											reject1();
										}
									}
								)
							} else {
								reject1('上传失败');
							}
						},
						(e) => {
							console.log(e);
						}
					);
				})(path,resolve1, reject1)
			}))
		}
		Promise.all(linshi_arr).then((res) => {
			resolve( true_arr)
		}).catch((err) => {
			console.log(err);
			reject('上传失败');
		})
	});
}
相关推荐
掘金酱8 分钟前
小册上新|玩🦐吗?ai 编程全栈指南了解一下?
前端·人工智能·ai编程
222you17 分钟前
Java 并发编程(1)
java·开发语言
小小小小宇25 分钟前
富文本编辑器知识体系(一)
前端
C++ 老炮儿的技术栈26 分钟前
Linux 文件系统目录架构全解析
linux·服务器·c语言·开发语言·c++
发现一只大呆瓜37 分钟前
深度拆解 fetch-event-source库实现原理
前端·javascript·面试
2601_9534656139 分钟前
HLS.js 原生开发!m3u8live.cn打造最贴合项目的 M3U8 在线播放器
开发语言·前端·javascript·python·json·ecmascript·前端开发工具
前端Hardy44 分钟前
为什么资深前端都在悄悄学 WebAssembly?
前端·javascript·面试
发现一只大呆瓜1 小时前
SSE 流式传输:中断超时处理
前端·javascript·面试
szcsun51 小时前
python中包、模块的层级关系,以及import、from...import...的相关用法
开发语言·python
阿猿收手吧!1 小时前
【C++】高并发内存池架构与设计解析
开发语言·c++·架构