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

study夏羽's avatar
study夏羽 已提交
7 8 9 10 11 12 13 14 15
<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
2.1.2  
DCloud_JSON 已提交
16 17
	*/
	export default {
study夏羽's avatar
study夏羽 已提交
18
		name: "cloud-image",
DCloud_JSON's avatar
2.1.2  
DCloud_JSON 已提交
19 20
		emits:['click'],
		props: {
study夏羽's avatar
study夏羽 已提交
21 22 23 24 25 26 27
			mode: {
				type:String,
				default () {
					return 'widthFix'
				}
			},
			src: {
DCloud_JSON's avatar
2.1.2  
DCloud_JSON 已提交
28 29 30 31
				// type:String,
				default () {
					return ""
				}
study夏羽's avatar
study夏羽 已提交
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
2.1.2  
DCloud_JSON 已提交
44
			}
study夏羽's avatar
study夏羽 已提交
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
		},
		watch: {
			src:{
				handler(src) {
					if (src&&src.substring(0, 8) == "cloud://") {
						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
2.1.2  
DCloud_JSON 已提交
67 68 69 70 71 72
		data() {
			return {
				cSrc:false
			};
		}
	}
study夏羽's avatar
study夏羽 已提交
73
</script>