热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

uniapp的上传

hello,我又要细说uniapp了附件上传,图片上传,视频上传应该是目前手机比较常见的功能,但是对于上传还是有一些需要注

hello,我又要细说uniapp了

附件上传,图片上传,视频上传应该是目前手机比较常见的功能,但是对于上传还是有一些需要注意

上传 - 一般有图片上传,附件视频


图片上传

图片的上传 -  直接动手机或者摄像头

官网地址:

uni-app官网


附件或者视频

官网:

uni-app官网

注意 - 微信小程序和app是不支持这个api的 - 对于微信小程序wx.chooseMessageFile(可以从微信聊天会话中进行选择

关于app的上传附件,可以利用原生进行,这篇文章中有记录uniapp实现常用功能_哆来A梦没有口袋的博客-CSDN博客_uniapp常用功能

选择完之后就是上传,uniapp有自己的上传

上传 

uni-app官网

上传也很好理解,都有案例,如果要上传自己的参数,可以写在formData里面

其实写这篇文章主要不是讲这几个api,而是讲假设要自己上传附件给后端应该怎么做

用post,上传base64给后端

uni.getFileSystemManager() - 获取全局唯一的文件管理器,利用readFile方法进行转码

要注意的是每个小程序有自己的规范

uni-app官网

写个案例

uni.chooseImage({count: 1,success: (res) => {wx.getFileSystemManager().readFile({filePath: res.tempFilePaths[0],encoding: "base64",success: (result) => {this.form[name] = 'data:image/png;base64,' + result.data;this[name] = result.data;this.$forceUpdate();}})}})

这个base64文件就是你要传给后端的图片了,

关于上传多个图片给后端

1,循环遍历用uniapp自己的upload方法

2. 利用base64, 在一个接口上传多个图片给后端


APP选择附件

 首先了解一下renderjs - uni-app官网

使用这个是因为当时上传附件使用u-view上传附件,结果在h5可以上传附件,但是其实在app端是不支持上传图片的,但是做也没有注意,为了解决这个问题,就写了一个原生input来实现上传附件,

其实uniapp是有上传的api的,但是刚好附件上传api只支持h5,也不支持app,

上传附件组件


顺便贴一个封装的上传附件的代码

import {Config
} from '../utils/config.js'import $ from '@/js/jquery-3.4.1.min.js'class UploadApi {constructor() {}//obj为 u-upload控件 选择的文件返回 - obj.url// eg [{"url":"blob:http://localhost:8083/56d15704-2537-46fd-b188-fedfc2b8b35f","progress":0,"error":false,"file":{}}] uploadFile(formData, obj) {return new Promise((resolve, reject) => {uni.uploadFile({url: Config.getInstance().getBaseUrl() + '/api/common/upload.do',filePath: obj.url,name: 'file',formData: formData,success: res => {const data = JSON.parse(res.data)// console.log("上传文件返回 data:" + JSON.stringify(data))if (data.code == "9000") {resolve(data.data)// console.log("上传文件返回 成功:" + data.data)} else {reject(data)// console.log("上传文件返回 失败:" + JSON.stringify(data))}},fail: (e) => {console.log("上传文件fail返回:" + e)reject(e)}})})}/*** @param {File} file 文件对象* @param {Integer} fileType 1 图片 2 视频 * */uploadFileByJquery(file, fileType) {return new Promise((resolve, reject) => {var formData = new FormData();formData.append("file", file); //上传一个files对象formData.append("fileType", fileType); //需要上传的多个参数$.ajax({url: Config.getInstance().getBaseUrl() + '/api/common/upload.do',type: "post",data: formData,processData: false,contentType: false,success: function(res) {resolve(res.data);},error: function(err) {reject("网络连接失败,稍后重试", err);}})})}/// 上传多图uploadFiles(formData, objs) {let num;if (objs) {num = objs.length;}return new Promise(async (resolve, reject) => {let queue = new Array()try {for (let i = 0; i }export {UploadApi
}

除了上传,一定还有回显,预览图片和附件,一定要记得地址要正确,不然会显示失败

import {Config
} from '@/utils/config.js';
const config = new Config();export function searchPdf(url) {let allUrl = url.replace("\\", "\/");if(!url.includes('http')) {allUrl = config.getImgPdfUrl() + allUrl;}console.log("allUrl: ",allUrl);if (url.includes('jpeg') || url.includes('jpg') || url.includes('png')) {console.log(allUrl, 'ALLImag')uni.previewImage({urls: [allUrl],fail: () => {console.log("预览图片失败", JSON.stringify(err))uni.showToast({title: '预览图片失败',icon: 'none'});},success(index, tapIndex) {console.log("预览图片成功", index, tapIndex)}});return} else {uni.showLoading({title: '正在打开,请等待'});uni.downloadFile({url: allUrl,fail: () => {uni.hideLoading()uni.showToast({title: '预览文件失败',icon: 'none'});},success: function(res) {console.log(res, 'res')var filePath = res.tempFilePath;console.log(filePath, 'folefasa',filePath)uni.openDocument({filePath: filePath,success: function(res) {console.log("预览文件成功", res)uni.hideLoading();},fail(err) {console.log("预览文件失败", err)uni.hideLoading();uni.showToast({title: '预览文件失败',icon: 'none'});}});},})}}

码字不易,点个赞啊!




推荐阅读
  • JavaScript 中创建对象的多种方法
    本文详细介绍了 JavaScript 中创建对象的几种常见方式,包括对象字面量、构造函数和 Object.create 方法,并提供了示例代码和属性描述符的解释。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 云函数与数据库API实现增删查改的对比
    本文将深入探讨使用云函数和数据库API实现数据操作(增删查改)的不同方法,通过详细的代码示例帮助读者更好地理解和掌握这些技术。文章不仅提供代码实现,还解释了每种方法的特点和适用场景。 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • 微信小程序中实现位置获取的全面指南
    本文详细介绍了如何在微信小程序中实现地理位置的获取,包括通过微信官方API和腾讯地图API两种方式。文中不仅涵盖了必要的准备工作,如申请开发者密钥、下载并配置SDK等,还提供了处理用户授权及位置信息获取的具体代码示例。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了如何使用 PHP 接收并处理微信支付的回调结果,确保支付通知能够被正确接收和响应。 ... [详细]
  • 微信小程序:授权登录与手机号绑定
    本文详细介绍了微信小程序中用户授权登录及绑定手机号的流程,结合官方指引和实际开发经验,提供了一套完整的实现方案,帮助开发者更好地理解和应用。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 程序员如何优雅应对35岁职业转型?这里有深度解析
    本文探讨了程序员在职业生涯中如何通过不断学习和技能提升,优雅地应对35岁左右的职业转型挑战。我们将深入分析当前热门技术趋势,并提供实用的学习路径。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有