uniapp多图上传、一次性上传多张图片

哈喽大家好,今后只分享思维方法,一来让大家思考,二来提升我自己的逻辑思维。为了共同学习进步,

用 uni-file-picker 组件, 文件选择上传

<view class="image-box">
			<uni-file-picker 
				title="最多选择9张图片"
				fileMediatype="image" 
				file-extname="jpg,png"
				mode="grid" 
				:auto-upload="true"
				@select="select" 
				@success="success" 
				@fail="fail" 
			/>
			
		</view>

js方法,选中文件图片,返回路径数组,然后遍历上传到服务器

			// 获取上传状态
			select(e){
				uni.showToast({
					title: '稍等',
					icon: 'none'
				});
				let tempFilePaths = e.tempFilePaths;
				for (var i = 0; i < tempFilePaths.length; i++) {
					this.uploadFile(tempFilePaths[i])
				}
			},

js方法  this.uploadFile

uploadFile(tempFilePaths) {
    			let token = uni.getStorageSync('token');
				// 图片上传
				uni.uploadFile({
					url: 'https://xxx.com/api/v1/worker/updateFile',
					filePath: tempFilePaths,
					name: 'file',
					method: 'POST',
					header: {
						authorization: 'Bearer ' + token
					},
					success: (uploadFileRes) => {
						// 提取图片url
						const res = JSON.parse(uploadFileRes.data);
						if (res.code == 200) {
							this.form.picture.push(res.data); // 上传成功返回的业务数据
							uni.showToast({
								title: '上传成功',
								icon: 'none'
							})
						}
					}
				});
			},

总结:

1.选择文件图片,

2.获取到文件路径。

3.遍历一个个执行上传

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
uni-file-pickeruni-app框架中的一个组件,用于在移动端应用中实现图片上传功能。通过该组件,用户可以选择图片并将其上传服务器。 以下是使用uni-file-picker组件实现图片上传的步骤: 1. 在页面中引入uni-file-picker组件,并设置相关属性: ```html <template> <view> <uni-file-picker limit="1" ref="files" :auto-upload="false" @select="select" @delete="del" v-model="one"></uni-file-picker> <button @click="upload">上传图片</button> </view> </template> ``` 其中,limit属性用于限制选择图片的数量,ref属性用于获取组件实例,auto-upload属性设置为false表示不自动上传图片,@select和@delete分别是选择图片和删除图片时触发的事件,v-model用于双向绑定选择的图片。 2. 在页面的script标签中定义相关方法: ```javascript <script> export default { data() { return { one: [] // 存储选择的图片 } }, methods: { select(files) { // 选择图片时触发的方法 this.one = files }, del(files) { // 删除图片时触发的方法 this.one = files }, upload() { // 上传图片的方法 // 可以在这里调用接口将图片上传服务器 console.log(this.one) } } } </script> ``` 在select方法中,将选择的图片赋值给one变量;在del方法中,将删除图片后的结果赋值给one变量;在upload方法中,可以调用接口将选择的图片上传服务器。 通过以上步骤,就可以在uni-app中使用uni-file-picker组件实现图片上传功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值