cloud-image.vue 1.5 KB
Newer Older
DCloud_JSON's avatar
DCloud_JSON 已提交
1
<template>
2
	<view @click="onClick" :style="{width,height}" style="justify-content: center;">
DCloud_JSON's avatar
DCloud_JSON 已提交
3 4 5 6
		<image v-if="cSrc" :style="{width,height}" :src="cSrc" :mode="mode"></image>
	</view>
</template>

7 8 9 10 11 12 13 14 15 16
<script>
	/**
	* cloud-image 
	* @description 兼容普通资源和unicloud图片资源渲染的组件
	* @property {String} mode	图片裁剪、缩放的模式。默认为widthFix,支持所有image组件的mode值
	* @property {String} src	资源完了链接或uniCloud云存储资源的fileid
	* @property {String} width	图片的宽,默认为:100rpx
	* @property {String} height	图片的高,默认为:100rpx
	* @event {Function} click 点击 cloud-image 触发事件
	*/
DCloud_JSON's avatar
DCloud_JSON 已提交
17
	export default {
雪洛's avatar
雪洛 已提交
18
		name: "cloud-image",
19
		emits:['click'],
DCloud_JSON's avatar
DCloud_JSON 已提交
20
		props: {
雪洛's avatar
雪洛 已提交
21 22 23 24 25 26 27
			mode: {
				type:String,
				default () {
					return 'widthFix'
				}
			},
			src: {
DCloud_JSON's avatar
DCloud_JSON 已提交
28 29 30 31
				// type:String,
				default () {
					return ""
				}
雪洛's avatar
雪洛 已提交
32 33 34 35 36 37 38 39 40 41 42 43
			},
			width: {
				type:String,
				default () {
					return '100rpx'
				}
			},
			height: {
				type:String,
				default () {
					return '100rpx'
				}
DCloud_JSON's avatar
DCloud_JSON 已提交
44
			}
雪洛's avatar
雪洛 已提交
45 46 47 48
		},
		watch: {
			src:{
				handler(src) {
49
					if (src&&src.substring(0, 8) == "cloud://") {
雪洛's avatar
雪洛 已提交
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
						uniCloud.getTempFileURL({
							fileList: [src]
						}).then(res=>{
							this.cSrc = res.fileList[0].tempFileURL
						})
					}else{
						this.cSrc = src
					}
				},
				immediate: true
			}
		},
		methods:{
			onClick(){
				this.$emit('click')
			}
		},
DCloud_JSON's avatar
DCloud_JSON 已提交
67 68 69 70 71 72
		data() {
			return {
				cSrc:false
			};
		}
	}
雪洛's avatar
雪洛 已提交
73
</script>