tiny-vue/examples/sites/demos/pc/app/image/slot-composition-api.vue

57 lines
1.1 KiB
Vue

<template>
<div class="demo-image__slot">
<div>
<p>加载中</p>
<tiny-image :src="url">
<template #placeholder>
<div class="image-slot">加载中<span class="dot">...</span></div>
</template>
</tiny-image>
</div>
<div>
<p>默认加载失败</p>
<tiny-image :src="errorUrl"> </tiny-image>
</div>
<div>
<p>自定义加载失败</p>
<tiny-image :src="errorUrl">
<template #error>
<div class="err-pic">
图片已丢失<br />
<span>404 IMAGE</span>
</div>
</template>
</tiny-image>
</div>
</div>
</template>
<script setup>
import { ref } from 'vue'
import { Image as TinyImage } from '@opentiny/vue'
const url = ref(`${import.meta.env.VITE_APP_BUILD_BASE_URL}static/images/mountain.png`)
</script>
<style scoped>
.demo-image__slot {
display: flex;
flex-wrap: wrap;
}
.demo-image__slot > div {
padding: 0 20px;
}
.tiny-image {
width: 150px;
height: 100px;
}
.err-pic {
font-size: 18px;
text-align: center;
line-height: 1.5;
}
.err-pic span {
color: red;
}
</style>