You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
194 lines
4.4 KiB
194 lines
4.4 KiB
12 months ago
|
<template>
|
||
|
<view class="u-empty" v-if="show" :style="{
|
||
|
marginTop: marginTop + 'rpx'
|
||
|
}">
|
||
|
<u-icon
|
||
|
:name="src ? src : 'empty-' + mode"
|
||
|
:custom-style="iconStyle"
|
||
|
:label="text ? text : icons[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>
|
||
|
/**
|
||
|
* empty 内容为空
|
||
|
* @description 该组件用于需要加载内容,但是加载的第一页数据就为空,提示一个"没有内容"的场景, 我们精心挑选了十几个场景的图标,方便您使用。
|
||
|
* @tutorial https://www.uviewui.com/components/empty.html
|
||
|
* @property {String} color 文字颜色(默认#c0c4cc)
|
||
|
* @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>
|
||
|
*/
|
||
|
export default {
|
||
|
name: "u-empty",
|
||
|
props: {
|
||
|
// 图标路径
|
||
|
src: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
// 提示文字
|
||
|
text: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
// 文字颜色
|
||
|
color: {
|
||
|
type: String,
|
||
|
default: '#c0c4cc'
|
||
|
},
|
||
|
// 图标的颜色
|
||
|
iconColor: {
|
||
|
type: String,
|
||
|
default: '#c0c4cc'
|
||
|
},
|
||
|
// 图标的大小
|
||
|
iconSize: {
|
||
|
type: [String, Number],
|
||
|
default: 120
|
||
|
},
|
||
|
// 文字大小,单位rpx
|
||
|
fontSize: {
|
||
|
type: [String, Number],
|
||
|
default: 26
|
||
|
},
|
||
|
// 选择预置的图标类型
|
||
|
mode: {
|
||
|
type: String,
|
||
|
default: 'data'
|
||
|
},
|
||
|
// 图标宽度,单位rpx
|
||
|
imgWidth: {
|
||
|
type: [String, Number],
|
||
|
default: 120
|
||
|
},
|
||
|
// 图标高度,单位rpx
|
||
|
imgHeight: {
|
||
|
type: [String, Number],
|
||
|
default: 'auto'
|
||
|
},
|
||
|
// 是否显示组件
|
||
|
show: {
|
||
|
type: Boolean,
|
||
|
default: true
|
||
|
},
|
||
|
// 组件距离上一个元素之间的距离
|
||
|
marginTop: {
|
||
|
type: [String, Number],
|
||
|
default: 0
|
||
|
},
|
||
|
iconStyle: {
|
||
|
type: Object,
|
||
|
default() {
|
||
|
return {}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
icons: {
|
||
|
car: '购物车为空',
|
||
|
page: '页面不存在',
|
||
|
search: '没有搜索结果',
|
||
|
address: '没有收货地址',
|
||
|
wifi: '没有WiFi',
|
||
|
order: '订单为空',
|
||
|
coupon: '没有优惠券',
|
||
|
favor: '暂无收藏',
|
||
|
permission: '无权限',
|
||
|
history: '无历史记录',
|
||
|
news: '无新闻列表',
|
||
|
message: '消息列表为空',
|
||
|
list: '列表为空',
|
||
|
data: '数据为空'
|
||
|
},
|
||
|
// icons: [{
|
||
|
// icon: 'car',
|
||
|
// text: '购物车为空'
|
||
|
// },{
|
||
|
// icon: 'page',
|
||
|
// text: '页面不存在'
|
||
|
// },{
|
||
|
// icon: 'search',
|
||
|
// text: '没有搜索结果'
|
||
|
// },{
|
||
|
// icon: 'address',
|
||
|
// text: '没有收货地址'
|
||
|
// },{
|
||
|
// icon: 'wifi',
|
||
|
// text: '没有WiFi'
|
||
|
// },{
|
||
|
// icon: 'order',
|
||
|
// text: '订单为空'
|
||
|
// },{
|
||
|
// icon: 'coupon',
|
||
|
// text: '没有优惠券'
|
||
|
// },{
|
||
|
// icon: 'favor',
|
||
|
// text: '暂无收藏'
|
||
|
// },{
|
||
|
// icon: 'permission',
|
||
|
// text: '无权限'
|
||
|
// },{
|
||
|
// icon: 'history',
|
||
|
// text: '无历史记录'
|
||
|
// },{
|
||
|
// icon: 'news',
|
||
|
// text: '无新闻列表'
|
||
|
// },{
|
||
|
// icon: 'message',
|
||
|
// text: '消息列表为空'
|
||
|
// },{
|
||
|
// icon: 'list',
|
||
|
// text: '列表为空'
|
||
|
// },{
|
||
|
// icon: 'data',
|
||
|
// text: '数据为空'
|
||
|
// }],
|
||
|
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</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>
|