【uniapp-上传图片单个图片和多个图片到数据库】

单个图片上传功能

思路,首先选择图片的功能是uni.chooseImage({})

		uni.chooseImage({
				count: 9, //图片的数量,默认是9
				success: (res) => {
				//在选择图片后,我们会在res.tempFilePaths以数组的形式里面获取我们的图片路径
					console.log(res.tempFilePaths);
				}
		})

在这里插入图片描述

这里获取的链接只是本地图片的一个地址,但是我们需要的是将图片这一个文件上传到数据库,这里我们需要用到uni.uploadFile({})

		uni.uploadFile({
				url: 'http://192.168.1.120:8080/ikun/common/upload',
				filePath: 这里需要我们的图片路径,
				success: (res) => {
					// 如果上传成功的话,我们可以看到后端返回的一个在线的链接(不知道的可以跟后端沟通一下)
					console.log(res);
				}
					
		})

接下来我们将 uni.uploadFile({}) 放在 uni.chooseImage({})success:(){}

uni.chooseImage({
			count: 9, //图片的数量,默认是9
			success: (res) => {
				//在选择图片后,我们会在res.tempFilePaths以数组的形式里面获取我们的图片路径
				console.log(res.tempFilePaths);
				
				uni.uploadFile({
					url: 'http://192.168.1.120:8080/ikun/common/upload',
					filePath: res.tempFilePaths[0],  //我们将选择图片后获取的路径放到这里,要记住 选择图片后获取的路径 是数组的形式
					success: (res) => {
						// 如果上传成功的话,我们可以看到后端返回的一个在线的链接(不知道的可以跟后端沟通一下
						console.log(res);
					}
				})
				
			}
})

在这里插入图片描述
但是这个数据我们不好获取,我们需要进行转换成对象,这里使用JSON.parse()

console.log( JSON.parse(res.data).data);

在这里插入图片描述

我们将获取来的值复制给某一个变量,在 **uni.request({})**中传参过去,就完成了向后端上传图片的功能了

多个图片上传功能

但是我们只会单个图片是不够的,我们还需要学会多个图片上传,实现多个图片上传,我们只需要在上传的代码加上一个for循环就好了

我们在uni.chooseImagesuccess 中先准备一个for循环,在 for循环 中放入 uni.uploadFile

uni.chooseImage({
			count: 9, //图片的数量,默认是9
			success: (res) => {
				//在选择图片后,我们会在res.tempFilePaths以数组的形式里面获取我们的图片路径
				console.log(res.tempFilePaths);
				
				uni.uploadFile({
					url: 'http://192.168.1.120:8080/ikun/common/upload',
					filePath: res.tempFilePaths[i],  //我们将选择图片后获取的路径放到这里,要记住 选择图片后获取的路径 是数组的形式
					success: (res) => {
						// 如果上传成功的话,我们可以看到后端返回的一个在线的链接(不知道的可以跟后端沟通一下
						console.log(res);
					}
				})
				
			}
})

看,你已经拿到了多个图片的链接了
在这里插入图片描述

但是我们拿到的都是单个的链接,我们需要将他们放在同一个数组里面,我们需要在data里面准备一个数组类型的变量,然后在 uni.uploadFilesuccess 中将单个的链接都放在这个数组类型的变量汇总

data() {
	return {
		morePic: []
	}
},
uni.uploadFile({
	url: 'http://192.168.1.120:8080/ikun/common/upload',
	filePath: res.tempFilePaths[0],  //我们将选择图片后获取的路径放到这里,要记住 选择图片后获取的路径 是数组的形式
	success: (res) => {
	// 如果上传成功的话,我们可以看到后端返回的一个在线的链接(不知道的可以跟后端沟通一下)
	this.morePic.push(JSON.parse(res.data).data)
	}	
})

我们单独准备一个console.log()来答应一下我们的morePic看一下效果

showMorePic(){
	console.dir(this.morePic.join('间隔'));
}

看,你成功的拿到了
在这里插入图片描述

以上就是上传单个图片和多个图片的教程,希望你学会了!!!

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,针对您的问题,我可以提供以下代码示例,用于实现Vue的Element UI Upload组件上传单个图片并带删除和放大功能: HTML模板代码: ``` <template> <div> <el-upload class="upload-demo" action="/your-upload-api" :before-upload="beforeUpload" :on-success="onSuccess" :on-error="onError" :show-file-list="false" > <div v-if="!imageUrl" class="upload-plus"> <i class="el-icon-plus"></i> <div class="upload-text">上传图片</div> </div> <div v-else class="upload-success"> <img :src="imageUrl" alt="uploaded image"> <div class="upload-actions"> <span class="upload-delete" @click="deleteImage">删除图片</span> <span class="upload-enlarge" @click="enlargeImage">放大图片</span> </div> </div> </el-upload> </div> </template> ``` Vue组件代码: ``` <script> export default { data() { return { imageUrl: '' } }, methods: { beforeUpload(file) { const isJPG = file.type === 'image/jpeg' || file.type === 'image/png' if (!isJPG) { this.$message.error('上传图片只能是 JPG 或 PNG 格式!') return false } const isLt2M = file.size / 1024 / 1024 < 2 if (!isLt2M) { this.$message.error('上传图片大小不能超过 2MB!') return false } }, onSuccess(response) { this.imageUrl = response.data.url }, onError(error) { this.$message.error('上传图片失败!') }, deleteImage() { this.imageUrl = '' }, enlargeImage() { this.$alert(`<img src="${this.imageUrl}" style="max-width: 100%;">`, '放大图片', { dangerouslyUseHTMLString: true }) } } } </script> ``` 在该示例中,我们使用了Vue的Element UI Upload组件来实现图片上传功能。我们通过`before-upload`钩子函数来限制上传图片的格式和大小。在上传成功时,我们将返回的图片URL赋值给`imageUrl`属性,以便在页面上显示上传图片。我们还使用了一个删除按钮和一个放大按钮,分别用于删除和放大图片。当用户点击放大按钮时,我们使用`$alert`方法来展示放大后的图片

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值