liangbowen 89089d1476 已拣货删除 | 2 months ago | |
---|---|---|
.. | ||
components | 2 months ago | |
changelog.md | 2 months ago | |
package.json | 2 months ago | |
readme.md | 2 months ago |
#jade-image-upload 图片上传组件
写插件不易,好用的话请5星好评,向身边朋友推荐吧ヾ(´▽‘)ノ。
注:本组件目前兼容微信小程序、H5,其它平台未实际测试过。
##完整示例 注:建议使用下载后的示例,不要直接复制本示例以免出现莫名bug 下面的this.uploadTask的onProgressUpdate()方法 不知道为什么每次上传都被篡改成this.uploadTask.Update()
<template>
<view class="media-container">
<jade-image-upload
:list="media"
:control="control"
:maxCount="maxCount"
:compressSize="compressSize"
:compressQuality="compressQuality"
:compressWidth='compressWidth'
:imageSize="imageSize"
@chooseFile="chooseFile"
@imgDelete="mediaDelete">
</jade-image-upload>
<!-- 数据变化的JSON -->
<view style="padding: 20rpx;box-sizing: border-box;display: flex;flex-direction: column;">
图片上传:
<!-- #ifdef H5 -->
<view style="padding: 20rpx;word-break: break-all;">{{media.length ? media: '暂无数据'}}</view>
<!-- #endif -->
<!-- #ifndef H5 -->
<view style="padding: 20rpx;word-break: break-all;">{{media.length ? JSON.stringify(media): '暂无数据'}}</view>
<!-- #endif -->
</view>
</view>
</template>
<script>
export default {
data() {
return {
control: true,
maxCount: 6,
compressSize: 0.2,
imageSize: 2,
compressQuality: 0.8,
compressWidth: 375,
uploadTask: null,
media: [], //数据源
};
},
methods: {
//上传
chooseFile(e) {
this.uploadFileToServe(e)
},
//中断上传并删除
mediaDelete(e) {
this.uploadTask ? this.uploadTask.abort() : ''
this.media.splice(e,1)
},
//上传逻辑处理
uploadFileToServe(urlList) {
if (!urlList || urlList.length <= 0) {
return
};
//以七牛云为例,可根据实际需求灵活调整
uni.request({
url: 'qiniu', //后端接口,仅为示例,并非真实接口地址。
method: 'GET',
success: (res) => {
let token = res.data.data; //拿到上传七牛所必须的token
urlList.forEach((item) => {
this.uploadTask = uni.uploadFile({
url: 'qiniu', //七牛上传接口,仅为示例
filePath: item.src,
name: 'file',
formData: {
'token': token
},
success: (res) => {
let data = JSON.parse(res.data) //七牛返回的数据
if (!data.data.url) {
item.status = 'error'
item.progress = '上传失败'
} else {
item.status = 'success'
item.progress = '上传成功'
item.src = data.data.url
}
}
});
this.uploadTask.onProgressUpdate((res) => {
item.percent = res.progress
this.media.splice(item.index,1,item)
})
})
}
});
},
}
}
</script>
<style lang="scss" scoped>
.media-container {
padding: 30rpx 26rpx;
box-sizing: border-box;
}
</style>
名称 | 类型 | 默认值 | 描述 |
---|---|---|---|
list | Array | [] | 数据源 |
control | Boolean | true | 是否显示上传控件 |
activeColor | String | #25C55A | 进度条颜色 |
deleteBtn | Boolean | true | 是否显示删除按钮 |
maxCount | Number | 3 | 上传最大数量 |
compressSize | Number | 5 | 照片超出压缩大小 MB |
imageSize | Number | 20 | 照片限制大小 MB |
compressQuality | Number | 0.99 | 照片压缩质量,取值范围0~1(非h5端仅对jpg有效) |
compressWidth | Number | 750 | 照片压缩宽度 px(仅h5支持) |
sourceType | Array | ['album', 'camera'] | album 从相册选图,camera 使用相机,默认二者都有。如需直接开相机或直接选相册,请只使用一个选项 |
名称 | 说明 |
---|---|
chooseFile | 返回的值:对象集合 |
imgDelete | 返回的值:删除的图片下标,基本不用。主要为了中断上传处理 |
##QQ交流群 465808513