Files
vant/packages/sku/components/SkuImgUploader.vue
T
2018-12-22 11:23:45 +08:00

105 lines
2.2 KiB
Vue

<template>
<div :class="b()">
<!-- 头部 -->
<van-uploader
:disabled="!!paddingImg"
:after-read="afterReadFile"
:max-size="maxSize * 1024 * 1024"
@oversize="onOversize"
>
<div :class="b('header')">
<div v-if="paddingImg">正在上传...</div>
<template v-else>
<icon name="photograph" />
<span class="label">{{ value ? '重拍' : '拍照' }}</span>
<icon name="photo" />
<span class="label">{{ value ? '重新选择照片' : '选择照片' }}</span>
</template>
</div>
</van-uploader>
<!-- 图片列表区域 -->
<div
v-if="paddingImg || imgList.length > 0"
class="van-clearfix"
>
<!-- 已有的图片,图片右上角显示删除按钮 -->
<div
v-for="img in imgList"
:class="b('img')"
>
<img :src="img">
<icon
name="clear"
:class="b('delete')"
@click="$emit('input', '')"
/>
</div>
<!-- 正在上传的图片,有上传等待提示 -->
<div
v-if="paddingImg"
:class="b('img')"
>
<img :src="paddingImg">
<loading
type="spinner"
:class="b('uploading')"
/>
</div>
</div>
</div>
</template>
<script>
import VanUploader from '../../uploader';
import create from '../../utils/create';
export default create({
name: 'sku-img-uploader',
components: {
VanUploader
},
props: {
value: String,
uploadImg: Function,
maxSize: {
type: Number,
default: 6
}
},
data() {
return {
// 正在上传的图片base 64
paddingImg: ''
};
},
computed: {
imgList() {
return this.value && !this.paddingImg ? [this.value] : [];
}
},
methods: {
afterReadFile(file) {
// 上传文件
this.paddingImg = file.content;
this.uploadImg(file.file, file.content).then(img => {
this.$emit('input', img);
this.$nextTick(() => {
this.paddingImg = '';
});
}).catch(() => {
this.paddingImg = '';
});
},
onOversize() {
this.$toast(`最大可上传图片为${this.maxSize}MB,请尝试压缩图片尺寸`);
}
}
});
</script>