u-empty.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. <template>
  2. <view class="u-empty" v-if="show" :style="{
  3. marginTop: marginTop + 'rpx'
  4. }">
  5. <u-icon
  6. :name="src ? src : 'empty-' + mode"
  7. :custom-style="iconStyle"
  8. :label="text ? text : icons[mode]"
  9. label-pos="bottom"
  10. :label-color="color"
  11. :label-size="fontSize"
  12. :size="iconSize"
  13. :color="iconColor"
  14. margin-top="38"
  15. ></u-icon>
  16. <view class="u-slot-wrap">
  17. <slot name="bottom"></slot>
  18. </view>
  19. </view>
  20. </template>
  21. <script>
  22. /**
  23. * empty 内容为空
  24. * @description 该组件用于需要加载内容,但是加载的第一页数据就为空,提示一个"没有内容"的场景, 我们精心挑选了十几个场景的图标,方便您使用。
  25. * @tutorial https://www.uviewui.com/components/empty.html
  26. * @property {String} color 文字颜色(默认#c0c4cc)
  27. * @property {String} text 文字提示(默认“无内容”)
  28. * @property {String} src 自定义图标路径,如定义,mode参数会失效
  29. * @property {String Number} font-size 提示文字的大小,单位rpx(默认28)
  30. * @property {String} mode 内置的图标,见官网说明(默认data)
  31. * @property {String Number} img-width 图标的宽度,单位rpx(默认240)
  32. * @property {String} img-height 图标的高度,单位rpx(默认auto)
  33. * @property {String Number} margin-top 组件距离上一个元素之间的距离(默认0)
  34. * @property {Boolean} show 是否显示组件(默认true)
  35. * @event {Function} click 点击组件时触发
  36. * @event {Function} close 点击关闭按钮时触发
  37. * @example <u-empty text="所谓伊人,在水一方" mode="list"></u-empty>
  38. */
  39. export default {
  40. name: "u-empty",
  41. props: {
  42. // 图标路径
  43. src: {
  44. type: String,
  45. default: ''
  46. },
  47. // 提示文字
  48. text: {
  49. type: String,
  50. default: ''
  51. },
  52. // 文字颜色
  53. color: {
  54. type: String,
  55. // default: '#c0c4cc'
  56. default: '#B0B9C3'
  57. },
  58. // 图标的颜色
  59. iconColor: {
  60. type: String,
  61. default: '#c0c4cc'
  62. },
  63. // 图标的大小
  64. iconSize: {
  65. type: [String, Number],
  66. // default: 120
  67. default: 280
  68. },
  69. // 文字大小,单位rpx
  70. fontSize: {
  71. type: [String, Number],
  72. default: 26
  73. },
  74. // 选择预置的图标类型
  75. mode: {
  76. type: String,
  77. default: 'data'
  78. },
  79. // 图标宽度,单位rpx
  80. imgWidth: {
  81. type: [String, Number],
  82. default: 120
  83. },
  84. // 图标高度,单位rpx
  85. imgHeight: {
  86. type: [String, Number],
  87. default: 'auto'
  88. },
  89. // 是否显示组件
  90. show: {
  91. type: Boolean,
  92. default: true
  93. },
  94. // 组件距离上一个元素之间的距离
  95. marginTop: {
  96. type: [String, Number],
  97. default: 0
  98. },
  99. iconStyle: {
  100. type: Object,
  101. default() {
  102. return {}
  103. }
  104. }
  105. },
  106. data() {
  107. return {
  108. icons: {
  109. car: '购物车为空',
  110. page: '页面不存在',
  111. search: '没有搜索结果',
  112. address: '没有收货地址',
  113. wifi: '没有WiFi',
  114. order: '订单为空',
  115. coupon: '没有优惠券',
  116. favor: '暂无收藏',
  117. permission: '无权限',
  118. history: '无历史记录',
  119. news: '无新闻列表',
  120. message: '消息列表为空',
  121. list: '列表为空',
  122. data: '数据为空'
  123. },
  124. // icons: [{
  125. // icon: 'car',
  126. // text: '购物车为空'
  127. // },{
  128. // icon: 'page',
  129. // text: '页面不存在'
  130. // },{
  131. // icon: 'search',
  132. // text: '没有搜索结果'
  133. // },{
  134. // icon: 'address',
  135. // text: '没有收货地址'
  136. // },{
  137. // icon: 'wifi',
  138. // text: '没有WiFi'
  139. // },{
  140. // icon: 'order',
  141. // text: '订单为空'
  142. // },{
  143. // icon: 'coupon',
  144. // text: '没有优惠券'
  145. // },{
  146. // icon: 'favor',
  147. // text: '暂无收藏'
  148. // },{
  149. // icon: 'permission',
  150. // text: '无权限'
  151. // },{
  152. // icon: 'history',
  153. // text: '无历史记录'
  154. // },{
  155. // icon: 'news',
  156. // text: '无新闻列表'
  157. // },{
  158. // icon: 'message',
  159. // text: '消息列表为空'
  160. // },{
  161. // icon: 'list',
  162. // text: '列表为空'
  163. // },{
  164. // icon: 'data',
  165. // text: '数据为空'
  166. // }],
  167. }
  168. }
  169. }
  170. </script>
  171. <style scoped lang="scss">
  172. @import "../../libs/css/style.components.scss";
  173. .u-empty {
  174. @include vue-flex;
  175. flex-direction: column;
  176. justify-content: center;
  177. align-items: center;
  178. height: 100%;
  179. }
  180. .u-image {
  181. margin-bottom: 20rpx;
  182. }
  183. .u-slot-wrap {
  184. @include vue-flex;
  185. justify-content: center;
  186. align-items: center;
  187. // margin-top: 20rpx;
  188. margin-top: 20rpx;
  189. }
  190. </style>