uniapp上传文件完全指南

作为一款跨平台的开发框架,uniapp 的文件上传功能既适用于 H5 端,也适用于小程序端。在本文中,我们将从 api 阐述、上传文件请求异常处理、上传文件到服务器等方面进行详细讲解。

一、uniapp上传文件api

uniapp 提供了 uni.uploadFile() 方法用于文件上传。该方法包括以下参数:

1、url: 必填项,上传的服务器地址。

2、filePath: 必填项,要上传文件资源的路径。

3、name: 必填项,文件对应的 key , 开发者在服务器端通过这个 key 可以获取到文件二进制内容。

4、header: HTTP 请求 Header。

5、formData: 上传文件的请求参数(如其他参数),需要与后台约定接口格式。

举个例子,以下为上传单个文件的代码示例:

uni.uploadFile({
  url: 'https://example.com/upload',
  filePath: 'filePath',
  name: 'file',
  success: (res) => {
    console.log('上传成功', res.data)
  },
  fail: (res) => {
    console.log('上传失败', res.data)
  }
})

二、uniapp小程序上传文件

在 uniapp 中,小程序上传文件与 H5 端类似,只需调用 uni.uploadFile() 方法即可。需要注意的是,小程序的上传文件大小限制是 2M(不同小程序平台可能会有所不同)。因此,为了节约空间,建议在上传前对文件进行压缩处理。

三、uniapp上传文件请求异常处理

请求异常可能会出现在以下情况:

1、调用 uni.uploadFile() 方法时传入的 filePath 不存在。

2、网络问题造成上传请求失败。

3、服务端拒绝上传请求。

当上传失败时,需要对异常进行处理。以下为请求异常处理示例:

uni.uploadFile({
  url: 'https://example.com/upload',
  filePath: 'filePath',
  name: 'file',
  success: (res) => {
    console.log('上传成功', res.data)
  },
  fail: (res) => {
    console.log('上传失败', res.data)
    uni.showToast({
      title: '上传失败,请稍后重试!',
      icon: 'none'
    })
  }
})

四、uniapp上传文件到服务器

在上传文件到服务器之前,需要先确认服务器端的接口是否符合要求。通常,服务器返回的 response 应包含有文件上传的状态信息和上传成功后的文件地址等信息。

在 uniapp 中,可以通过监听 uni.uploadFile() 的 success 函数,来获取上传成功时服务器返回的信息。

uni.uploadFile({
  url: 'https://example.com/upload',
  filePath: 'filePath',
  name: 'file',
  success: (res) => {
    console.log('上传成功', res.data)
    // 请求服务端进行数据库修改或者其他操作
  },
  fail: (res) => {
    console.log('上传失败', res.data)
    uni.showToast({
      title: '上传失败,请稍后重试!',
      icon: 'none'
    })
  }
})

五、uniapp上传图片

在 uniapp 中上传图片与上传文件基本相同,需要调用 uni.uploadFile() 方法。在选择图片时,需先通过 uni.chooseImage() 方法选择要上传的图片,该方法有以下参数:

count: 选择图片的数量,默认为 1 张。

sizeType: 指定选择的图片大小类型(original 原图、compressed 压缩图),默认为 [‘original’, ‘compressed’]。

sourceType: 指定选择图片的来源(album 相册、camera 照相机),默认为 [‘album’, ‘camera’]。

以下为上传图片的代码示例:

uni.chooseImage({
  count: 1,
  sizeType: ['original', 'compressed'],
  sourceType: ['album', 'camera'],
  success: (chooseRes) => {
    var tempFilePaths = chooseRes.tempFilePaths

    uni.uploadFile({
      url: 'https://example.com/upload',
      filePath: tempFilePaths[0],
      name: 'file',
      success: (res) => {
        console.log('上传成功', res.data)
      },
      fail: (res) => {
        console.log('上传失败', res.data)
        uni.showToast({
          title: '上传失败,请稍后重试!',
          icon: 'none'
        })
      }
    })
  }
})

六、uniapp移动端文件上传

在 uniapp 移动端中,可通过 H5 的 input 标签上传文件。需要调用 uni.createSelectorQuery().select() 方法选择需要上传文件的 input 标签,然后调用一个 .onChange() 方法监听 input 的 onchange 事件,从而获取要上传的文件的信息。

以下代码为在移动端上传文件的代码示例:

uni.createSelectorQuery().select('#file-input').fields({ node: true, size: true })
  .exec((res) => {
    const file = res[0].node.files[0]

    const formData = new FormData()
    formData.append('file', file)

    uni.request({
      url: 'https://example.com/upload',
      method: 'POST',
      data: formData,
      header: {
        'content-type': 'multipart/form-data'
      },
      success: (res) => {
        console.log('上传成功', res.data)
      },
      fail: (res) => {
        console.log('上传失败', res.data)
        uni.showToast({
          title: '上传失败,请稍后重试!',
          icon: 'none'
        })
      }
    })
  })

七、uniapp上传图片组件

在 uniapp 中,可以使用 uni.uploadFile() 方法封装一个上传图片的组件。组件的作用是封装上传图片的代码,使得在调用时只需传入相应的参数即可实现上传图片功能。

以下为上传图片组件的代码示例:

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/285936.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-22 16:06
下一篇 2024-12-22 16:06

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • 运维Python和GO应用实践指南

    本文将从多个角度详细阐述运维Python和GO的实际应用,包括监控、管理、自动化、部署、持续集成等方面。 一、监控 运维中的监控是保证系统稳定性的重要手段。Python和GO都有强…

    编程 2025-04-29
  • Python wordcloud入门指南

    如何在Python中使用wordcloud库生成文字云? 一、安装和导入wordcloud库 在使用wordcloud前,需要保证库已经安装并导入: !pip install wo…

    编程 2025-04-29
  • Python应用程序的全面指南

    Python是一种功能强大而简单易学的编程语言,适用于多种应用场景。本篇文章将从多个方面介绍Python如何应用于开发应用程序。 一、Web应用程序 目前,基于Python的Web…

    编程 2025-04-29
  • Python小波分解入门指南

    本文将介绍Python小波分解的概念、基本原理和实现方法,帮助初学者掌握相关技能。 一、小波变换概述 小波分解是一种广泛应用于数字信号处理和图像处理的方法,可以将信号分解成多个具有…

    编程 2025-04-29
  • Python字符转列表指南

    Python是一个极为流行的脚本语言,在数据处理、数据分析、人工智能等领域广泛应用。在很多场景下需要将字符串转换为列表,以便于操作和处理,本篇文章将从多个方面对Python字符转列…

    编程 2025-04-29
  • Python初学者指南:第一个Python程序安装步骤

    在本篇指南中,我们将通过以下方式来详细讲解第一个Python程序安装步骤: Python的安装和环境配置 在命令行中编写和运行第一个Python程序 使用IDE编写和运行第一个Py…

    编程 2025-04-29
  • Python起笔落笔全能开发指南

    Python起笔落笔是指在编写Python代码时的编写习惯。一个好的起笔落笔习惯可以提高代码的可读性、可维护性和可扩展性,本文将从多个方面进行详细阐述。 一、变量命名 变量命名是起…

    编程 2025-04-29
  • FusionMaps应用指南

    FusionMaps是一款基于JavaScript和Flash的交互式地图可视化工具。它提供了一种简单易用的方式,将复杂的数据可视化为地图。本文将从基础的配置开始讲解,到如何定制和…

    编程 2025-04-29
  • Python中文版下载官网的完整指南

    Python是一种广泛使用的编程语言,具有简洁、易读易写等特点。Python中文版下载官网是Python学习和使用过程中的重要资源,本文将从多个方面对Python中文版下载官网进行…

    编程 2025-04-29

发表回复

登录后才能评论