uniapp的上传
hello,我又要细说uniapp了附件上传,图片上传,视频上传应该是目前手机比较常见的功能,但是对于上传还是有一些需要注意上传 - 一般有图片上传,附件视频图片上传图片的上传 - 直接动手机或者摄像头官网地址:uni-app官网附件或者视频官网:uni-app官网注意 - 微信小程序和app是不支持这个api的 - 对于微信小程序wx.chooseMessageFile(可以从微信聊天会话中进行
hello,我又要细说uniapp了
附件上传,图片上传,视频上传应该是目前手机比较常见的功能,但是对于上传还是有一些需要注意
上传 - 一般有图片上传,附件视频
图片上传
图片的上传 - 直接动手机或者摄像头
官网地址:

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

关于app的上传附件,可以利用原生进行,这篇文章中有记录uniapp实现常用功能_哆来A梦没有口袋的博客-CSDN博客_uniapp常用功能
选择完之后就是上传,uniapp有自己的上传
上传
上传也很好理解,都有案例,如果要上传自己的参数,可以写在formData里面

其实写这篇文章主要不是讲这几个api,而是讲假设要自己上传附件给后端应该怎么做
用post,上传base64给后端
uni.getFileSystemManager() - 获取全局唯一的文件管理器,利用readFile方法进行转码
要注意的是每个小程序有自己的规范

写个案例
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,

上传附件组件
<template>
<view :file="file" :change:file="uploadFile.changeFile" :randomID="randomID" :change:randomID="uploadFile.changeRandomID">
<view @click="uploadFile.addUpload" hover-class="slot-btn__hover" hover-stay-time="150">
<view> + </view>
</view>
<view id="upload-container" class="input" style="display: none;">
附件上传
</view>
</view>
</template>
<script>
import {
Config
} from '@/utils/config.js'
import {
UploadApi
} from '@/api/upload.js';
const uploadApi = new UploadApi();
export default {
name: 'uploadFile',
data() {
return {
file: '',
randomID: ''
}
},
methods: {
async upload(url) {
console.log('uplaidfIKE')
this.$emit('uploaded', url)
}
}
}
</script>
<script module="uploadFile" lang="renderjs">
import {
UploadApi
} from '@/api/upload.js';
const uploadApi = new UploadApi();
import {
Config
} from '@/utils/config.js';
const config = new Config();
let prefix = config.getImgPdfUrl();
var input;
export default {
data() {
return {
};
},
mounted(){
// 创建附件上传
input = document.createElement('input'); //创建元素
input.type = 'file' //添加file类型
input.onchange = (event) => {
// this.$ownerInstance.callMethod('submit', editor.txt.html())
uploadApi.uploadFileByJquery(input.files[0], 2).then(r => {
//this.$ownerInstance 获取当前组件的 ComponentDescriptor 实例
this.$ownerInstance.callMethod('upload', r)
})
}
document.getElementById('upload-container').appendChild(input)
},
methods: {
changeFile(newValue, oldValue, ownerVm, vm) {
},
changeRandomID(newValue, oldValue, ownerVm, vm) {
},
addUpload() {
input.click()
}
}
}
</script>
<style lang="scss">
.slot-btn {
width: 140rpx;
height: 140rpx;
display: flex;
justify-content: center;
// align-items: center;
line-height: 130rpx;
font-size: 60rpx;
background: rgb(244, 245, 246);
border-radius: 10rpx;
}
.slot-btn__hover {
background-color: rgb(235, 236, 238);
}
</style>
顺便贴一个封装的上传附件的代码
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 < num; i++) {
console.log(objs[i], 'sss ,i ');
let data = await this.uploadFile(formData, objs[i]);
queue.push(data)
};
// resolve(queue.join(','))
resolve(queue)
} catch (e) {
reject(e)
}
})
}
}
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'
});
}
});
},
})
}
}
码字不易,点个赞啊!
更多推荐



所有评论(0)