CNCEC_APP/uni_modules/uview-pro/components/u-empty/u-empty.vue

109 lines
3.2 KiB
Vue
Raw Normal View History

2026-03-25 14:54:15 +08:00
<template>
<view
v-if="show"
class="u-empty"
:class="customClass"
:style="$u.toStyle({ marginTop: marginTop + 'rpx' }, customStyle)"
>
<u-icon
:name="src ? src : 'empty-' + mode"
:custom-style="iconStyle"
:label="text ? text : (icons as any)[mode]"
label-pos="bottom"
:label-color="color"
:label-size="fontSize"
:size="iconSize"
:color="iconColor"
margin-top="14"
></u-icon>
<view class="u-slot-wrap">
<slot name="bottom"></slot>
</view>
</view>
</template>
<script lang="ts">
export default {
name: 'u-empty',
options: {
addGlobalClass: true,
// #ifndef MP-TOUTIAO
virtualHost: true,
// #endif
styleIsolation: 'shared'
}
};
</script>
<script setup lang="ts">
import { EmptyProps } from './types';
import { $u, useLocale } from '../../';
import { computed } from 'vue';
const { t } = useLocale();
/**
* empty 内容为空
* @description 该组件用于需要加载内容但是加载的第一页数据就为空提示一个"没有内容"的场景 我们精心挑选了十几个场景的图标方便您使用
* @tutorial https://uviewpro.cn/zh/components/empty.html
* @property {String} color 文字颜色默认var(--u-light-color)
* @property {String} text 文字提示默认无内容
* @property {String} src 自定义图标路径如定义mode参数会失效
* @property {String Number} font-size 提示文字的大小单位rpx默认28
* @property {String} mode 内置的图标见官网说明默认data
* @property {String Number} img-width 图标的宽度单位rpx默认240
* @property {String} img-height 图标的高度单位rpx默认auto
* @property {String Number} margin-top 组件距离上一个元素之间的距离默认0
* @property {Boolean} show 是否显示组件默认true
* @event {Function} click 点击组件时触发
* @event {Function} close 点击关闭按钮时触发
* @example <u-empty text="所谓伊人,在水一方" mode="list"></u-empty>
*/
const props = defineProps(EmptyProps);
/**
* 预置图标对应的提示文字
*/
const icons = computed(() => {
return {
car: t('uEmpty.car'),
page: t('uEmpty.page'),
search: t('uEmpty.search'),
address: t('uEmpty.address'),
wifi: t('uEmpty.wifi'),
order: t('uEmpty.order'),
coupon: t('uEmpty.coupon'),
favor: t('uEmpty.favor'),
permission: t('uEmpty.permission'),
history: t('uEmpty.history'),
news: t('uEmpty.news'),
message: t('uEmpty.message'),
list: t('uEmpty.list'),
data: t('uEmpty.data')
};
});
</script>
<style scoped lang="scss">
@import '../../libs/css/style.components.scss';
.u-empty {
@include vue-flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100%;
}
.u-image {
margin-bottom: 20rpx;
}
.u-slot-wrap {
@include vue-flex;
justify-content: center;
align-items: center;
margin-top: 20rpx;
}
</style>