具体使用方法在官网:
概述 | uniCloudhttps://doc.dcloud.net.cn/uniCloud/storage/dev.html#clouduploadfile下面以用户上传头像为例:
当我们把button组件中的open-type改为"chooseAvatar"时,就能够选择图片
data:image/s3,"s3://crabby-images/223f6/223f68e716ab8fc54a8490a549e73bc59adec2c1" alt=""
data:image/s3,"s3://crabby-images/a14f5/a14f598db60c9fe50bb16a6e9b10ea768d54d65f" alt=""
给这个button添加一个点击事件,并接收到事件对象
data:image/s3,"s3://crabby-images/9c77d/9c77d6cdd5f29eea629c3cd931f29ce21a9e52a0" alt=""
在打印出来的对象中可以看到该图片的临时路径,我们只需要把这个临时路径上传到云存储中就行
data:image/s3,"s3://crabby-images/40ef1/40ef195f93874af875b7dfa07804aa012c55fc5e" alt=""
现在我们用uniCloud.uploadFile将图片上传到云存储:
javascript
function onChooseAvatar(e) {
let avatarUrl = e.detail.avatarUrl;
uniCloud.uploadFile({
filePath:avatarUrl,
cloudPath:"" // 上传到云存储的文件名
}).then(res=>{
console.log(res);
})
}
data:image/s3,"s3://crabby-images/54db3/54db3fee53130da7fa6549b08861669fb29cb5b4" alt=""
我们可以在res中获取返回的图片路径,并且在云存储库中能够看到保存的图像,名字为我们定义的cloudPath
data:image/s3,"s3://crabby-images/24ebd/24ebde61ffd6407c1f070cd32ed714a260567b54" alt=""
注:上传后图像会被压缩
我们所有上传的图像都会被存储在cloudstorage文件夹中
data:image/s3,"s3://crabby-images/45f22/45f22cbe52ee45cf4e21c4ea4b300d022ab68dfd" alt=""
如果我们想把图像上传到其他文件夹下,可以使用如下操作:
首先设置cloudPathAsRealPath:true,然后配置文件路径
我这里把所有上传的图像放在userAvatar文件中,又单独按照日期分类,把当前的时间戳作为图像名。
data:image/s3,"s3://crabby-images/eff03/eff03caab09c52c92b0d68f8ed15ee7544c4cb22" alt=""
有效路径是res中的fileID
data:image/s3,"s3://crabby-images/8bf2c/8bf2c822ff9cd37aeadcc93096e9620c43b1a212" alt=""
所以我们可以把数据更新到数据库中
并渲染出来