首页 >web前端 >uni-app >聊聊Uniapp的照片上传和删除操作

聊聊Uniapp的照片上传和删除操作

PHPz
PHPz原创
2023-04-18 14:09:041506浏览

近年来,在移动应用开发领域,Uniapp已经成为越来越多开发者的首选。Uniapp是一款全新的开发框架,通过这一框架,开发者可以开发多端应用,从而提高了工程师的开发效率。本文将对Uniapp的照片上传和删除操作进行详细的介绍和讲解。

一、图片上传的实现

相机和图片选取是常见的功能之一,Uniapp提供了丰富的API接口,使得相机、相册或是微信朋友圈、在线文件等多种方式进行图片的选择和上传成为可能。下面我们将详细介绍Uniapp的API接口如何实现图片上传的功能。

  1. 选择图片并上传

Uniapp提供了一个非常好用的组件,uni-upload,可以实现异步上传文件,接下来通过uni-upload实现选择图片上传的功能。

首先在前端页面上添加如下代码:

<view>
   <uni-upload :upload-url="&#39;your_upload_url&#39;" :on-success="success" :on-fail="fail" @click="upload">
     <view class="button">上传图片</view>
   </uni-upload>
</view>

这段代码中,我们定义了一个uni-upload组件,其中upload-url属性是图片上传的URL地址,on-successon-fail分别对应上传成功和失败的回调函数。@click属性是点击后触发上传函数。

然后我们需要在Vue实例中配置successfail两个回调函数:

methods: {
   success(res){
     console.log("上传成功");
   },
   fail(err){
     console.log("上传失败");
   },
   upload(){
     uni.chooseImage({
       sizeType: ['compressed'],
       sourceType: ['album', 'camera'],
       success: (res) => {
         const tempFilePaths = res.tempFilePaths;
         uni.uploadFile({
           url: this.uploadUrl,
           filePath: tempFilePaths[0],
           name: 'file',
           success: (res) => {
            this.success(res)
           },
           fail: (err) => {
            this.fail(err)
           }
         });
       }
     });
   }
}

这段代码中,我们首先定义了successfail两个回调函数,当上传成功或者失败后,就会执行相应的回调函数。在upload函数中,我们使用uni.chooseImage方法选择图片,获取到临时文件路径,并使用uni.uploadFile方法将文件上传到服务器。name属性表示文件对应的键值,即服务器上接收文件的参数名。

这样就实现了在Uniapp中选择图片并上传的功能。

  1. 上传图片并获取返回结果

在上传图片的过程中,我们需要在上传成功后获取到后端返回的结果,这样可以获取到上传图片的URL地址或者其他图片上传的信息。

uni.uploadFile这个接口中,我们在success回调函数中增加一个参数,用来接收上传成功后后端返回的结果。修改后的代码如下:

methods: {
   success(res){
     const data = res.data;
     console.log(data);
     console.log("上传成功");
   },
   fail(err){
     console.log("上传失败");
   },
   upload(){
     uni.chooseImage({
       sizeType: ['compressed'],
       sourceType: ['album', 'camera'],
       success: (res) => {
         const tempFilePaths = res.tempFilePaths;
         uni.uploadFile({
           url: this.uploadUrl,
           filePath: tempFilePaths[0],
           name: 'file',
           success: (res) => {
            this.success(res);
           },
           fail: (err) => {
            this.fail(err);
           }
         });
       }
     });
   }
}

上面的代码中我们在success中打印了服务器返回的数据。

二、图片删除的实现

在我们的应用程序中,有时候需要删除已经上传的图片,这样可以节省存储空间并达到优化程序的目的,Uniapp提供了很多API接口来实现这个功能。下面给出两种方式:

  1. 使用uni.removeSavedFile方法删除图片

这种方式是在应用中使用的图片是由应用自己下载或拍摄的,使用uni.removeSavedFile可以将照片从应用目录或内存中删除。

首先定义删除方法:

methods:{
  deleteImage(index) {
    const filePath = this.uploadList[index].filePath;
    uni.removeSavedFile({
      filePath: filePath,
      success(res) {
        console.log(res)
      },
      fail(err) {
        console.log(err)
      }
    });
  }
}

在组件中使用删除方法:

<view v-for="(item,index) in uploadList" :key="index">
    <image :src="item.filePath" mode="aspectFit" style="width:50px;height:50px"></image>
    <view v-on:click="deleteImage(index)">删除</view>
</view>

这段代码中,我们在列表组件上使用v-for指令,依次获取要删除的图片的信息,deleteImage方法则是用来删除相应的文件。

  1. 向服务器发起删除请求

在我们的应用中,如果使用的是服务器上的图片,那么可以使用向服务器发送删除请求的方式来删除图片。这种方式与使用uni.removeSavedFile方法不同的是,我们需要向服务器发送请求,并将该图片在后台删除。

定义删除方法:

methods:{
  deleteImage(index) {
    const url = 'your_delete_url';
    const fileID = this.uploadList[index].url;
    uni.request({
      url: url,
      method: 'DELETE',
      data:{
        fileID:fileID,
        key:'value'  // 可以添加其他参数
      },
      success: (res) => {
        console.log(res);
      },
      fail: (err) => {
        console.log(err);
      }
    });
  }
}

通过这种方式,我们向服务器发送了一条删除请求,后端接收到这条请求后,就可以删除服务器中的相应数据。

三、总结

以上就是在Uniapp中实现图片上传和删除功能的两种方式。在实际应用中,我们可以根据实际需求进行选择,从而在程序中实现完美的图片上传和删除功能。同时,我们也可以在使用过程中采用性能更好的方式,达到更好的程序性能。

以上是聊聊Uniapp的照片上传和删除操作的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn