| <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> |