热门标签 | 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'});}});},})}}

码字不易,点个赞啊!




推荐阅读
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 小程序自动授权和手动接入的方式及操作步骤
    本文介绍了小程序支持的两种接入方式:自动授权和手动接入,并详细说明了它们的操作步骤。同时还介绍了如何在两种方式之间切换,以及手动接入后如何下载代码包和提交审核。 ... [详细]
  • 31.项目部署
    目录1一些概念1.1项目部署1.2WSGI1.3uWSGI1.4Nginx2安装环境与迁移项目2.1项目内容2.2项目配置2.2.1DEBUG2.2.2STAT ... [详细]
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社区 版权所有