小程序wx.uploadFile异步问题

问题:小程序上传文件后我需要后端返回的一个值,但这个值总是在最后面导致需要这个值的方法总是报错,打印测试后发现这它是异步的。但直接使用 await来等待也不行。 

uploadImg.wxml

<view class="upload-wrap"><view class="list-wrap"><view class="item" wx:for="{{fileList}}" wx:key="index" wx:for-index="index" wx:for-item="item"><image class="file" src="{{item.url}}" data-url="{{item.url}}" bindtap="viewImage"></image><view wx:if="{{!disabled}}" class="icon-delete" data-index="{{index}}" bindtap="delFile"><image class="icon-delete" src="/images/common/icon-delete.png" mode="widthFix"></image></view></view><view wx:if="{{!disabled && fileList.length<maxCount}}" class="add-wrap" bindtap="chooseFile"><image class="icon-camera" src="/images/common/icon-camera.png" mode="widthFix"></image></view></view>
</view>

uploadImg.js

const app = getApp();
Component({properties: {pageFileList: {optionalTypes: [Array, String],value: () => {return []},observer: function (newValue, oldValue) {let list;if (!newValue) {list = [];} else if (typeof newValue == 'string') {list = JSON.parse(newValue);}this.setData({fileList: list})}},disabled: {type: Boolean,default: false},maxSize: {type: Number,value: 5242880, // 5M},maxCount: {type: Number,value: 9,},category: {type: String,value: 'Personal', // 1:Personal,2:Article,3:Meeting},name: {type: String,value: 'Image'},// 文件类型fileType: {type: Number,value: 1, // 1:Image,2:Video,3:Excel,4:PDF文件},},data: {fileList: [],},methods: {// 选择图片chooseFile() {let choseImgCount;let fileListLen = this.data.fileList.length;let maxCount = this.data.maxCount;// 计算每次可上传的文件数量if (fileListLen == maxCount) {choseImgCount = 0;} else if (maxCount - fileListLen > 9) {choseImgCount = 9;} else {choseImgCount = maxCount - fileListLen;}wx.chooseImage({count: choseImgCount,sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有sourceType: ['album', 'camera'], // 选择图片的来源success: (res) => {// 限制最大文件体积let overSizeIndex = res.tempFiles.findIndex(v => v.size > this.data.maxSize);if (overSizeIndex > -1) {let msg = "";if (res.tempFiles.length > 1) {msg = "第" + (overSizeIndex + 1) + "个文件已经超过了最大文件限制:"} else {msg = "该文件已经超过了最大文件限制:"}app.alert.show(msg + (this.data.maxSize / 1024 / 1024).toFixed(0) + "M,请重新上传~");return;}this.uploadFile(res.tempFilePaths);}});},// 上传图片async uploadFile(tempFilePaths) {wx.showLoading({title: '上传中...',mask: true})for (let i = 0; i < tempFilePaths.length; i++) {await this.uploadFileHandler(tempFilePaths, i);if (i == tempFilePaths.length - 1) {this.triggerEvent("uploadFiles", { list: this.data.fileList, name: this.data.name });wx.showToast({title: '上传成功',icon: 'none',duration,})}}},uploadFileHandler(tempFilePaths, i) {let self = this;let fileList = self.data.fileList;return new Promise((resolve, reject) => {wx.uploadFile({url: app.siteinfo.apiUrl + '', // 需要用HTTPS,同时在微信公众平台后台添加服务器地址filePath: tempFilePaths[i], // 上传的文件本地地址name: 'file', // 服务器定义的Key值header: {'content-type': 'multipart/form-data','cookie': wx.getStorageSync('cookie')},formData: {uploadDir: self.data.category,fileType: self.data.fileType,},success: function (res) {wx.hideLoading()if (res.statusCode == 200) {let result = JSON.parse(res.data);if (result.status) {let list = [{ name: self.data.name, url: result.data.fileurl }];fileList = fileList.concat(list);self.setData({ fileList });resolve();} else {app.alert.show(result.errmsg, reject(result.errmsg));}} else {app.alert.show('状态:' + res.statusCode + ',提示:' + res.errMsg, reject(res.errMsg));}},fail: function (err) {wx.hideLoading()app.alert.show(err.errMsg, reject(err.errMsg));}});})},// 删除图片delFile(e) {wx.showModal({title: '提示',content: '确定要删除吗?',success: res => {if (res.confirm) {let fileList = this.data.fileList;fileList.splice(parseInt(e.currentTarget.dataset.index), 1);this.setData({ fileList })this.triggerEvent("uploadFiles", {list: fileList,name: this.data.name});wx.showToast({title: '删除成功',icon: 'success',duration: 2000})}}})},// 预览图片viewImage(e) {let urls = this.data.fileList.map(item => { return item.url });wx.previewImage({current: e.currentTarget.dataset.url,urls});},}
})

uploadImg.less

.upload-wrap {.list-wrap {display: flex;flex-wrap: wrap;.item {position: relative;width: 188rpx;height: 188rpx;margin-top: 40rpx;margin-right: calc(~"(100% - 564rpx) / 3");.file {width: 100%;height: 100%;vertical-align: middle;border-radius: 8rpx;}.icon-delete {width: 40rpx;position: absolute;right: -10rpx;top: -10rpx;}}}.add-wrap {display: flex;align-items: center;justify-content: center;flex-direction: column;width: 188rpx;height: 188rpx;margin-top: 40rpx;border: 1px dashed #979797;border-radius: 8rpx;background-color: #f9fafb;text-align: center;.icon-camera {width: 50rpx;height: 46rpx;pointer-events: none;}}
}

 uploadImg.json

{"component": true,"usingComponents": {}
}

应用

<upload-img category="Personal" pageFileList="{{form.image}}" maxCount="3" disabled bind:uploadFiles="uploadFiles">
</upload-img>

 data: {form: {image: '[{"name":"Image","url":"https://wechatmp.uatwechat.com/upload/PersonalCompressed/20230614/20230614114423503.jpeg"}]',video: ''},},uploadFiles(e) {let str = "form." + e.detail.name;let list = e.detail.list;if (list.length > 0) {this.setData({[str]: JSON.stringify(e.detail.list)})} else {this.setData({[str]: '',})}},

app.alert方法封装 alert.js,然后在在app.js引入可使用

const show = (message, showCancel, successCallback = function() {}) => {wx.showModal({title: '提示',content: message,confirmColor: '#DB6276',showCancel: showCancel,success(res) {if (res.confirm) {successCallback();}}})
}module.exports = {show
}

小程序上传多张图片

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

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

相关文章

【自撰写】【国际象棋入门】第4课 局面分析初步

第4课 局面分析初步 一、国际象棋的棋局阶段划分 随着对弈的进行&#xff0c;国际象棋棋局可以划分为3个阶段&#xff0c;分别是开局阶段、中局阶段和残局阶段。简单说来&#xff0c;开局阶段主要完成子力的出动和布局&#xff1b;中局阶段涉及到更多的子力协同配合和子力兑换…

镭速是如何做到传输中快速校验大文件的

在信息泛滥的当下&#xff0c;文件传输系统的效率与安全性成为企业和个人用户高度关注的焦点。传统上&#xff0c;文件传输依赖于如MD5或XXHash等单一的完整性校验机制。 然而&#xff0c;在多变的工作环境中&#xff0c;这些传统方法显得不够灵活。镭速&#xff0c;作为大文件…

【尚庭公寓SpringBoot + Vue 项目实战】后台用户信息管理(十七)

【尚庭公寓SpringBoot Vue 项目实战】后台用户信息管理&#xff08;十七&#xff09; 文章目录 【尚庭公寓SpringBoot Vue 项目实战】后台用户信息管理&#xff08;十七&#xff09;1、业务说明2、逻辑模型介绍3、接口开发3.1、根据条件分页查询后台用户列表3.2、根据ID查询后…

grafana连接influxdb2.x做数据大盘

连接influxdb 展示数据 新建仪表盘 选择存储库 设置展示

Handler机制

目录 一、简介二、相关概念解释2.1 Message&#xff08;消息&#xff09;2.2 Handler&#xff08;处理器&#xff09;2.2.1 Handler的构造方法2.2.2 Handler sendMessage&#xff08;&#xff09;相关的方法2.2.3 Handler dispatchMessage&#xff08;&#xff09;方法 2.3 Mes…

NSSCTF-Web题目9

目录 [SWPUCTF 2021 新生赛]sql 1、题目 2、知识点 3、思路 [SWPUCTF 2022 新生赛]xff 1、题目 2、知识点 3、思路 [FSCTF 2023]源码&#xff01;启动! 1、题目 2、知识点 3、思路 [SWPUCTF 2021 新生赛]sql 1、题目 2、知识点 SQL注入&#xff0c;空格、注释符等…

京东和天猫各渠道区别是什么?你了解吗?如何快速了解两个平台渠道推广

1.快车/直通车区别: 京东:不能投竞品词,能投定向商品选竞品,因为京东是卖平台流量和商品(自营(主收入)),不可以投竞品词是为了保护自己店铺的品牌流量; 天猫:只卖平台流量,不卖商品,所以允许竞品词投放; 2.竞品人群圈选: 因为数坊是自身品牌数据分析平台,所…

基于EXCEL数据表格创建省份专题地图

1 数据源 随着西藏于5月1日发布2022年一季度经济运行情况&#xff0c;31省份一季度GDP数据已全部出炉。 总量方面&#xff0c;粤苏鲁稳居前三&#xff1b;增速方面&#xff0c;23省份高于“全国线”&#xff0c;新疆表现最佳&#xff0c;增速达到7.0%。 表格表现数据不够直观…

Aeron:Multi-Destination-Cast

Multi-Destination-Cast&#xff08;MDC&#xff09;是一种功能&#xff0c;允许 Aeron 从单个 Publication 同时向多个目的地传送数据。Multiple-Destination-Cast是 Aeron 的一项高级功能&#xff0c;本指南将介绍如何开发一个简单示例的基本知识。 一、MDC Publications 注&…

MAP REDUCE

大数据处理框架概念 定义&#xff1a;由一系列组件构成&#xff0c;负责对数据系统中的数据进行计算。组件&#xff1a; 处理引擎&#xff1a;实际执行数据操作的独立组件。处理框架&#xff1a;包含多个协同工作的组件。 框架与引擎的区别 引擎&#xff1a;单一的&#xf…

NV-Embed论文阅读笔记

这是NVIDIA的一篇论文&#xff0c;LLM通常使用的是GPT的decoder范式作为一个生成模型&#xff0c;文章探讨如何利用这样的decoder生成模型来实现BERT这样的encoder的功能&#xff0c;即提取有效的embedding。现有的方法提取embedding的方式无非是 1 mean pooling&#xff1b; 2…

计算机相关专业是否仍是“万金油”的选择?

亲爱的朋友们&#xff1a; 2024 年高考已然落幕&#xff0c;数百万高三学子站在了人生的重要十字路口&#xff0c;面临着选择大学专业这一关键抉择。在这个节点上&#xff0c;计算机相关专业是否还能被称为“万金油”的选择呢&#xff1f; 相信大家都知道&#xff0c;在最近这几…

经典神经网络(11)VQ-VAE模型及其在MNIST数据集上的应用

经典神经网络(11)VQ-VAE模型及其在MNIST数据集上的应用 我们之前已经了解了PixelCNN模型。 经典神经网络(10)PixelCNN模型、Gated PixelCNN模型及其在MNIST数据集上的应用 今天&#xff0c;我们了解下DeepMind在2017年提出的一种基于离散隐变量&#xff08;Discrete Latent va…

celery骚操作之把任务写在类中可能造成的问题

celery注册异步函数是模块级别的&#xff0c;也就是同个模块不能有同名函数&#xff0c;比如搞个骚操作&#xff0c;将celery任务写在类中如下(注意这个静态方法是个特殊的装饰器&#xff0c;他实际是个描述器&#xff0c;他必须写在最上面) 实际注册的任务是apps.business.tas…

3D视觉引导机器人提升生产线的自动化水平和智能化程度

随着智能化技术的不断发展&#xff0c;汽车制造企业正积极寻求提升智能化水平的途径。富唯智能的3D视觉引导机器人抓取技术为汽车制造企业提供了一种高效、智能的自动化解决方案。 项目目标 某汽车制造企业希望通过引入智能化技术提升生产线的自动化水平和智能化程度。他们希望…

python错题(3)

round四舍五入 title()把单词首字母大写 all() 函数用于判断给定的可迭代参数 iterable 中的所有元素是否都为 TRUE&#xff0c;如果是返回 True&#xff0c;否则返回 False。 元素除了是 0、空、None、False 外都算 True 。空元组、空列表返回值为True&#xff0c;这里要特…

2023数A题——WLAN网络信道接入机制建模

A题——WLAN网络信道接入机制建模 思路&#xff1a;该题主要考察的WLAN下退避机制建模仿真。 资料获取 问题1&#xff1a; 假设AP发送包的载荷长度为1500Bytes&#xff08;1Bytes 8bits&#xff09;&#xff0c;PHY头时长为13.6μs&#xff0c;MAC头为30Bytes&#xff0c;MA…

是否可以外链代发?

当然是可以的&#xff0c;代发外链是一种有效的提升网站SEO排名和流量的方法。通过在高质量的网站上发布包含你网站链接的内容&#xff0c;可以提高你网站的权重和可信度。而在所有代发外链的方式中&#xff0c;GPB外链无疑是最好的选择。 GPB外链&#xff0c;每一条GPB外链都是…

【UE4】角色御剑飞行的蓝图实现

沉沉更鼓急&#xff0c;渐渐人声绝 吹灯窗更明&#xff0c;月照一天雪 UE4简单的实现御剑飞行的功能 契子✨ 所谓的御剑飞行的原理就跟 《御板》 飞行的原理差不多&#xff0c;不过是在人物脚上插把剑在飞行的时候显示出来罢了。简单来讲就是只要渲染做的足够牛&#xff0c;土鸡…

App上架和推广前的准备

众所周知&#xff0c;App推广的第一步是上架各大应用下载市场&#xff0c;然后才是其他推广渠道。所以本文主要分两部分&#xff0c;第一部分主要介绍的是上架各大应用市场方面的准备&#xff0c;第二部分主要介绍的是其他渠道推广方面的准备。 一、App上架前的准备 1.1 上架…