uni-app 如何实现选择和上传非图像、视频文件?

在 uni-app 中实现选择和上传非图像、视频文件,可根据不同端(App、H5、小程序)的特点,采用以下方法:

一、通用思路(多端适配优先推荐)

借助 uni.chooseFile 选择文件,再用 uni.uploadFile 上传,不过部分端有差异,需针对性处理:

1. 选择文件(uni.chooseFile
uni.chooseFile({count: 1, // 可选择文件数量,按需调整type: 'file', // 选择任意类型文件,若想限制类型,可结合 extension 筛选success: (res) => {const tempFilePath = res.tempFiles[0].path; // 获取选中文件的临时路径// 后续可执行上传等操作},fail: (err) => {console.error('选择文件失败:', err);}
});
  • 参数说明
    • count:控制最多选几个文件,按需设值。
    • type:设为 'file' 可选择非媒体文件;若想限定特定类型(如文档),可搭配 extension(H5 端支持 ),例 extension: ['.pdf', '.docx'] ,不过 App 和小程序端对 extension 支持度欠佳,复杂类型筛选可结合后续服务端校验。
    • 选中后,res.tempFiles 里存文件信息,含临时路径 path 、文件名 name 、大小 size 等 。
2. 上传文件(uni.uploadFile

拿到选择的文件临时路径后,用 uni.uploadFile 上传到服务器:

uni.uploadFile({url: 'https://your-server.com/upload', // 实际的服务端文件上传接口filePaths: [tempFilePath], // 前面选择文件得到的临时路径name: 'file', // 与服务端约定的接收文件的字段名formData: {// 可附带其他业务参数,如用户 ID、文件分类等userId: '123',category: 'document'},success: (uploadRes) => {const data = JSON.parse(uploadRes.data);console.log('上传成功,服务端返回:', data);// 可依据服务端返回做后续处理,如更新文件列表、提示用户等},fail: (err) => {console.error('上传失败:', err);}
});
  • 注意事项
    • url 要替换成真实的服务端上传接口地址,需服务端配合实现文件接收逻辑(如 Node.js + Express 用 multer 中间件、Java 用 Spring Boot 的文件上传解析等 )。
    • name 字段要和服务端接口约定一致,否则服务端无法正确识别文件。
    • 若需更灵活的请求头设置、进度监听等,可结合 uni.request 自己构建上传逻辑(把文件转成二进制流等方式 ),不过 uni.uploadFile 已封装常见场景,优先推荐。

二、App 端特殊处理(解决兼容性问题)

uni.chooseFile 在 App 端选非媒体文件有兼容性问题(如部分安卓机型选特定文件失败 ),可借助 5+App 的 plus.io.chooseFile 实现:

1. 选择文件(plus.io.chooseFile
// 仅 App 端有效,需判断平台后使用
if (uni.getSystemInfoSync().platform === 'android' || uni.getSystemInfoSync().platform === 'ios') {plus.io.chooseFile({title: '选择文件', // 选择文件的标题提示filter: '*', // 筛选文件类型,* 表示所有,也可设 '.pdf,.docx' 等multiple: false // 是否多选},(res) => {const fileInfo = res.files[0]; // 获取选中的文件信息const localPath = fileInfo.path; // 文件本地路径// 可通过 plus.io 进一步操作文件,如读取内容、转成可上传的格式// 示例:转成临时文件路径,用于 uni.uploadFileconst tempFilePath = plus.io.convertLocalFileSystemURL(localPath); // 执行上传等操作},(err) => {console.error('选择文件失败:', err);});
}
  • 优势:对 App 端文件系统兼容性更好,能处理一些 uni.chooseFile 覆盖不到的特殊文件选择场景(如安卓分区存储下的文件 )。
  • 不足:是 5+App 专有 API,H5 和小程序端无法使用,需做平台判断,增加代码复杂度。
2. 上传文件

拿到文件路径后,同样可用 uni.uploadFile 上传,若遇到文件格式不兼容问题(如服务端需特定二进制流 ),可先用 plus.io 读取文件内容转成合适格式再上传:

plus.io.resolveLocalFileSystemURL(localPath, (entry) => {entry.file((file) => {const fileReader = new plus.io.FileReader();fileReader.onloadend = (e) => {const buffer = e.target.result; // 文件内容的 Buffer 数据// 若服务端需要 FormData 格式,可构造后用 uni.request 上传const formData = new FormData();formData.append('file', new Blob([buffer]), file.name); uni.request({url: 'https://your-server.com/upload',method: 'POST',header: {'Content-Type': 'multipart/form-data'},data: formData,success: (res) => {console.log('上传成功:', res.data);}});};fileReader.readAsArrayBuffer(file);});
});

三、H5 端补充(利用浏览器特性)

H5 端除了用 uni.chooseFile ,还可直接用 HTML 原生的 <input type="file"> 实现更灵活的文件选择(若 uni.chooseFile 样式、功能满足不了需求时 ):

1. 在页面中添加 input 元素(可通过条件编译仅在 H5 端显示 )
<template><view><!-- #ifdef H5 --><input type="file" style="display: none;" ref="fileInput" @change="handleFileChange" /><button @click="openFileSelector">选择文件</button><!-- #endif --></view>
</template><script>
export default {methods: {openFileSelector() {this.$refs.fileInput.click(); // 触发文件选择框},handleFileChange(e) {const file = e.target.files[0]; // 获取选中的文件const fileReader = new FileReader();fileReader.onload = (event) => {const fileContent = event.target.result; // 文件内容,可转成 Base64 等// 若要上传,可构造 FormData 用 uni.request 或 axios 等上传const formData = new FormData();formData.append('file', file);uni.request({url: 'https://your-server.com/upload',method: 'POST',header: {'Content-Type': 'multipart/form-data'},data: formData,success: (res) => {console.log('上传成功:', res.data);}});};fileReader.readAsArrayBuffer(file);}}
}
</script>
  • 特点:完全基于浏览器原生能力,自定义程度高,可灵活控制文件选择后的处理流程(如读取文件内容预览、做加密等 ),但需自己处理多端兼容(仅 H5 端能用 ),且样式需自己调整。

四、小程序端限制与适配

小程序端 uni.chooseFile 本质是调用各小程序平台的文件选择 API,整体流程和前面通用方法一致,但有以下限制:

  • 文件类型与大小:不同小程序平台对可选择的文件类型、大小有约束(如微信小程序限制单文件最大 100MB 等 ),需在开发时注意。
  • 接口能力uni.uploadFile 需配置合法域名,且服务端要做相应跨域等配置,否则无法上传成功。

五、方案推荐与总结

  • 优先推荐:用 uni.chooseFile + uni.uploadFile 的通用方案,多端兼容性较好,能覆盖大部分场景(如上传文档、压缩包等非媒体文件 ),简单易实现。
  • App 端特殊场景:若通用方案有兼容性问题(如选文件失败 ),补充 plus.io.chooseFile 的方式,增强对 App 端文件系统的适配。
  • H5 端自定义需求:结合原生 <input type="file"> 实现更灵活的文件选择和预处理逻辑。

实际开发中,建议先尝试通用方案,遇到特定端问题(如 App 端选某些文件报错、H5 端样式不满意 ),再针对性用对应补充方案解决,同时注意服务端配合做好文件接收、校验逻辑 。

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

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

相关文章

正点原子[第三期]Arm(iMX6U)Linux移植学习笔记-12.1 Linux内核启动流程简介

前言&#xff1a; 本文是根据哔哩哔哩网站上“Arm(iMX6U)Linux系统移植和根文件系统构键篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。 引用&#xff1a; …

UDP与TCP通信协议技术解析

文章目录 协议基础原理TCP&#xff1a;可靠的面向连接通信UDP&#xff1a;高效的无连接通信 性能特征分析TCP性能表现UDP性能表现 应用场景分析TCP适用场景UDP适用场景 技术实现考量错误处理策略网络资源利用 选择决策框架可靠性需求评估性能要求分析 混合方案设计协议组合策略…

mysql 页的理解和实际分析

目录 页&#xff08;Page&#xff09;是 Innodb 存储引擎用于管理数据的最小磁盘单位B树的一般高度记录在页中的存储 innodb ibd文件innodb 页类型分析ibd文件查看数据表的行格式查看ibd文件 分析 ibd的第4个页&#xff1a;B-tree Node类型先分析File Header(38字节-描述页信息…

【优选算法】C++滑动窗口

1、长度最小的子数组 思路&#xff1a; class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {// 滑动窗口// 1.left0,right0// 2.进窗口( nums[right])// 3.判断// 出窗口// (4.更新结果)// 总和大于等于 target 的长度最小的 子数组…

ffmpeg(四):滤镜命令

FFmpeg 的滤镜命令是用于音视频处理中的强大工具&#xff0c;可以完成剪裁、缩放、加水印、调色、合成、旋转、模糊、叠加字幕等复杂的操作。其核心语法格式一般如下&#xff1a; ffmpeg -i input.mp4 -vf "滤镜参数" output.mp4或者带音频滤镜&#xff1a; ffmpeg…

408考研逐题详解:2009年第33题

2009年第33题 在 OSI 参考模型中&#xff0c;自下而上第一个提供端到端服务的层次是&#xff08; &#xff09; A. 数据链路层 \qquad B. 传输层 \qquad C. 会话层 \qquad D.应用层 解析 本题主要考查 OSI 参考模型各层的核心功能、端到端服务的定义。 OSI 参考模型&am…

CentOS 7.9安装Nginx1.24.0时报 checking for LuaJIT 2.x ... not found

Nginx1.24编译时&#xff0c;报LuaJIT2.x错误&#xff0c; configuring additional modules adding module in /www/server/nginx/src/ngx_devel_kit ngx_devel_kit was configured adding module in /www/server/nginx/src/lua_nginx_module checking for LuaJIT 2.x ... not…

自制喜悦字贴

一、想法 据说&#xff0c;把“喜悦”两个字挂在家里显眼的地方&#xff0c;时常看到&#xff0c;就能心情愉悦。刚好最近在学习前端flex布局&#xff0c;用代码实现&#xff0c;导出图片&#xff0c;打印出来&#xff0c;帖在家里&#xff0c;非常nice。现在分享给大家。 二…

每日八股文6.3

每日八股-6.3 Mysql1.COUNT 作用于主键列和非主键列时&#xff0c;结果会有不同吗&#xff1f;2.MySQL 中的内连接&#xff08;INNER JOIN&#xff09;和外连接&#xff08;OUTER JOIN&#xff09;有什么主要的区别&#xff1f;3.能详细描述一下 MySQL 执行一条查询 SQL 语句的…

量化面试绿皮书:6. 烧绳子计时

文中内容仅限技术学习与代码实践参考&#xff0c;市场存在不确定性&#xff0c;技术分析需谨慎验证&#xff0c;不构成任何投资建议。 6. 烧绳子计时 你有两根绳子&#xff0c;每根绳子燃烧需要1小时。但是任何一根绳子在不同点都有不同的密度&#xff0c;所以不能保证绳子内不…

2-深度学习挖短线股1

选短线个股的流程 &#xff08;1&#xff09;数据预处理&#xff0c;根据短线个股筛选标准&#xff0c;给个股日线数据打标。 &#xff08;2&#xff09;模型训练&#xff0c;针对每只股票&#xff0c;训练得到分类模型。 &#xff08;3&#xff09;结果预测&#xff0c;根据训…

【数据分析】探索婴儿年龄变化对微生物群落(呼吸道病毒和细菌病原体)结构的影响

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍1. 混合效应逻辑回归模型2. 随机森林模型3. Maaslin2 分析加载R包数据下载导入数据数据预处理混合效应逻辑回归模型分析微生物群落结构随年龄的变化随机森林模型预测病原体定植Maas…

实战:子组件获取父组件订单信息

最佳实践建议 优先使用 props&#xff1a;适合父子组件直接通信&#xff0c;数据流向清晰复杂场景用 eventBus&#xff1a;跨组件通信推荐使用 mitt 库避免过度使用 $parent&#xff1a;会导致组件耦合度高&#xff0c;难以维护provide/inject 适用于跨层级&#xff1a;如主题…

Spring Security深度解析:构建企业级安全框架

Spring Security深度解析:构建企业级安全框架 本文将深入探讨Spring Security安全框架的核心原理、架构设计和实际应用,帮助开发者全面掌握企业级应用安全防护技术。 目录 Spring Security概述核心架构与原理认证机制详解授权机制详解核心组件分析配置与集成高级特性应用安全…

计算矩阵A和B的乘积

根据矩阵乘法规则&#xff0c;编程计算矩阵的乘积。函数fix_prod_ele()是基本方法编写&#xff0c;函数fix_prod_opt()是优化方法编写。 程序代码 #define N 3 #define M 4 typedef int fix_matrix1[N][M]; typedef int fix_matrix2[M][N]; int fix_prod_ele(f…

《Brief Bioinform》: 鼠脑单细胞与Stereo-seq数据整合算法评估

一、写在前面 基因捕获效率、分辨率一直是空间转录组细胞类型识别的拦路虎&#xff0c;许多算法能够整合单细胞(single-cell, sc)或单细胞核(single-nuclear, sn)数据与空间转录组数据&#xff0c;从而帮助空转数据的细胞类型注释。此前我们介绍过近年新出炉的Stereo-seq平台&…

camera功能真的那么难用吗

背景 Android开发工作过程中&#xff0c;经常需要用到camera相关能力&#xff0c;比如&#xff1a;人脸识别&#xff0c;ai识别&#xff0c;拍照预览&#xff0c;摄像头录制等等需求。都需要使用到camera&#xff0c;且需要拿到camera的预览数据。但是每次开发这块代码都比较繁…

USART 串口通信全解析:原理、结构与代码实战

文章目录 USARTUSART简介USART框图USART基本结构数据帧起始位侦测数据采样波特率发生器串口发送数据 主要代码串口接收数据与发送数据主要代码 USART USART简介 一、USART 的全称与基本定义 英文全称 USART&#xff1a;Universal Synchronous Asynchronous Receiver Transmi…

LeetCode 152. 乘积最大子数组 - 动态规划解法详解

文章目录 问题描述解题思路动态规划状态定义状态转移方程完整代码实现复杂度分析示例解析关键点说明总结问题描述 给定一个整数数组 nums,请找出数组中乘积最大的连续子数组(该子数组中至少包含一个数字),并返回该子数组对应的乘积。 示例: 输入: [2,3,-2,4] 输出: 6 解…

Python: 操作 Excel折叠

💡Python 操作 Excel 折叠(分组)功能详解(openpyxl & xlsxwriter 双方案) 在处理 Excel 报表或数据分析时,我们常常希望通过 折叠(分组)功能 来提升表格的可读性和组织性。本文将详细介绍如何使用 Python 中的两个主流 Excel 操作库 —— openpyxl 和 xlsxwriter …