Files
lucky_shop/components/ns-empty/ns-empty.vue
2025-10-27 15:55:29 +08:00

96 lines
1.7 KiB
Vue

<template>
<view class="empty" :class="{ fixed: fixed }">
<view class="empty_img"><image :src="$util.img('public/uniapp/common/common-empty.png')" mode="aspectFit"></image></view>
<view class="color-tip margin-top title" :style="{ color: textColor + ' !important' }">{{ text }}</view>
<view class="color-tip margin-bottom font-size-sub">{{ subText }}</view>
<button type="primary" size="mini" class="button mini" @click="goIndex()" v-if="isIndex">{{ emptyBtn.text }}</button>
</view>
</template>
<script>
export default {
data() {
return {};
},
props: {
text: {
type: String,
default: '暂无相关数据'
},
subText: {
type: String,
default: ''
},
isIndex: {
type: Boolean,
default: true
},
emptyBtn: {
type: Object,
default: () => {
return { text: '去逛逛' };
}
},
fixed: {
type: Boolean,
default: false
},
textColor: {
type: String,
default: ''
}
},
methods: {
goIndex() {
if (this.emptyBtn.url) {
this.$util.redirectTo(this.emptyBtn.url, {}, 'redirectTo');
} else {
this.$util.redirectTo('/pages/index/index');
}
},
re(text) {
this.text = text;
}
}
};
</script>
<style lang="scss">
.empty {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
padding: $padding;
box-sizing: border-box;
justify-content: center;
.title {
font-size: 30rpx;
}
.empty_img {
width: 50%;
height: 450rpx;
image {
width: 100%;
height: 100%;
padding-bottom: $padding;
}
}
button {
min-width: 300rpx;
margin-top: 100rpx;
height: 70rpx;
line-height: 70rpx !important;
font-size: $font-size-base;
font-weight: bold;
border-radius: 100rpx;
}
}
.fixed {
position: fixed;
left: 0;
top: 20vh;
}
</style>