You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
107 lines
2.5 KiB
107 lines
2.5 KiB
<template>
|
|
<view class="margin-top">
|
|
<view class="cu-bar bg-white ">
|
|
<view class="action">
|
|
{{label}}
|
|
</view>
|
|
<view class="action">
|
|
{{imgList.length}}/{{maxImg}}
|
|
</view>
|
|
</view>
|
|
<view class="cu-form-group">
|
|
<view class="grid col-4 grid-square flex-sub">
|
|
<view class="bg-img" v-for="(item,index) in imgList" :key="index" @tap="ViewImage" :data-url="imgList[index]">
|
|
<image :src="imgList[index]" mode="aspectFill"></image>
|
|
<view class="cu-tag bg-red" @tap.stop="DelImg" :data-index="index">
|
|
<text class='cuIcon-close'></text>
|
|
</view>
|
|
</view>
|
|
<view class="solids" @tap="ChooseImage" v-if="imgList.length<maxImg">
|
|
<text class='cuIcon-cameraadd'></text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
|
|
export default {
|
|
name: 'MyImageUpoad',
|
|
props: {
|
|
value: {type:String,default:''},
|
|
label:{type:String,default:'图片上传'},
|
|
maxImg: {
|
|
type: Number,
|
|
default: 3
|
|
},
|
|
|
|
},
|
|
mounted:function(){
|
|
if (this.value.split(',')!=''){
|
|
this.value.split(',').forEach(res=>{
|
|
this.imgList.push(baseurl+res)
|
|
})
|
|
}
|
|
},
|
|
data() {
|
|
return {
|
|
imgList: [],
|
|
pathlist:[],
|
|
}
|
|
},
|
|
methods: {
|
|
ChooseImage() {
|
|
uni.chooseImage({
|
|
count: this.maxImg, //默认9
|
|
sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
|
|
sourceType: ['album','camera'], //从相册选择
|
|
success: (res) => {
|
|
uni.uploadFile({
|
|
url: `${baseurl}systemController/filedeal.do?isup=1`,
|
|
filePath: res.tempFilePaths[0],
|
|
name: 'file',
|
|
success: (uploadFileRes) => {
|
|
let path = JSON.parse(uploadFileRes.data).obj
|
|
this.pathlist.push(path);
|
|
this.$emit('input',this.pathlist.join(','))
|
|
if (this.imgList.length != 0) {
|
|
this.imgList = this.imgList.concat(res.tempFilePaths)
|
|
} else {
|
|
this.imgList = res.tempFilePaths
|
|
}
|
|
}
|
|
})
|
|
|
|
}
|
|
});
|
|
},
|
|
ViewImage(e) {
|
|
uni.previewImage({
|
|
urls: this.imgList,
|
|
current: e.currentTarget.dataset.url
|
|
});
|
|
},
|
|
DelImg(e) {
|
|
uni.showModal({
|
|
title: '提示',
|
|
content: '确认要删除吗',
|
|
cancelText: '取消',
|
|
confirmText: '确认',
|
|
success: res => {
|
|
if (res.confirm) {
|
|
this.pathlist.splice(e.currentTarget.dataset.index,1)
|
|
this.imgList.splice(e.currentTarget.dataset.index, 1)
|
|
this.$emit('input',this.pathlist.join(','))
|
|
}
|
|
}
|
|
})
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
|
|
</style>
|