tui-loading.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <template>
  2. <view class="tui-loading tui-loading__box" :class="{'tui-loading__fixed':fixed}" :style="{ backgroundColor: backgroundColor, color: color,position:fixed?'fixed':'static' }" v-if="type === 'column'">
  3. <image class="tui-loading__ani" :src="src"></image>
  4. <view class="tui-loading__text">{{ text }}</view>
  5. </view>
  6. <view v-else class="tui-loading tui-loading__row" :class="{'tui-loading__fixed':fixed}" :style="{position:fixed?'fixed':'static'}">
  7. <image class="tui-loading-row__ani" :src="rowsrc"></image>
  8. <view class="tui-loading__text">{{ text }}</view>
  9. </view>
  10. </template>
  11. <script>
  12. export default {
  13. name: 'tuiLoading',
  14. props: {
  15. //column or row
  16. type: {
  17. type: String,
  18. default: 'column'
  19. },
  20. text: {
  21. type: String,
  22. default: '加载中'
  23. },
  24. //type=column时生效
  25. color: {
  26. type: String,
  27. default: '#fff'
  28. },
  29. //type=column时生效
  30. backgroundColor: {
  31. type: String,
  32. default: 'rgba(0, 0, 0, 0.6)'
  33. },
  34. //type=column时生效
  35. src: {
  36. type: String,
  37. default:
  38. 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHgAAAB4CAMAAAAOusbgAAAARVBMVEUAAAD///////////////////////////////////////////////////////////////////////////////////////9SnXPCAAAAFnRSTlMA8ECgECCAYDDQ4MCwUL9wkN9vP49fRXb34AAAA1dJREFUaN7tmtmSozAMReXdxuyk+f9PnaW6o06CAdtSumqG8xqSi6QrGwfBxcXFD2OW5cP+pVsWDe9AL7YP6xO9mj1w0t3CmkK0H0yhd0qsBzBoazutZxDKACFSrefpJZmFUfad0vpVtonWOvkHZ62Kzas0QcLnJ0dFuxGOHNqny8QMVfjw6By5c+n4GHnwVOGq7tiDD3G74uq234Idzbmue7hVXZtmYfEncqRDicekKPSo+Z6o/EI7bB6Zfc+hXBl1R13V+0Jm6uL3inCiKGZX6g7ENwXKrrwfEB3uyubszYovXahBx3ve9LkvoG4lcc36pf7zagu16JCzeo4E8aLy+TJL1CXAfJWtP7zHKcsPp+NYh6NEY2posOeSbT4v64CMiLU7dvQIVGAsqzyuSKOBEHvCXwHvjZAGQ94PuAVaJIa8X2EDxMSDkGXh0lG9KCkMmCnkbdNq6oARt7t8Oa6A0dhhx1oREPpe9ukVxgEHBnOdyLQAHkI61wqtxcCQ9rXATDPgk9uef7kjFl+PiRJH4EKlijwmniyp15DEqtYBFz7VyQKXLR5ST9iJLibvZLuZiQh8qO1+kizPHq+hNXpT2AIjrlnX+GIii8J8eJPatyQwcwn/j8ISu5uZwj7+d4QBl8w3I3CT4EOnjjcCeJHJXUsDJ35LeHhDPw0yaesROIkmaesAjJgVtmjZizygd99b5CnunCQVsNGlFsbAnOs+tfkNTMdFzOjuqb0HJlR6J4h4uKHH7CSz47SX2tsIGr6Dm9mNyPGFrHZrqBuuKvuD1dhxGbs/6tOGuJcxoObMM5/QQIoWx8G0HA99IwZ89EZzAEI6PKMc+kt4ykRjix4ne6IrczhjGmzmoAn/dOlyXpgrumPoeLrr6JRd1hOkJVN2mW9mFZGywwbJU+51pa/QWJnKk6/o3xbX/Xxl0ZUPvxXp4nREqyuG31zZnFD5nJHp8ZsVc0I9NkTOFFsw9UN7t5x8W1E9oQSdyJ2p1fP04srKSUUlz0zLiqQlKwbwppvfVZ0DjvkR/bWO2urDbIp2t2n9knWk/+ojorfzsty9v8y2n/DTZgBKZLueInZAjR7CkWoYDLBgXCvSs/uoyoJ3Y3zWjOPg4T14KQf7m0FKqeHi4uJH+QUYYoTOYC/s2wAAAABJRU5ErkJggg=='
  39. },
  40. //type=row时生效
  41. rowsrc: {
  42. type: String,
  43. default:
  44. 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFoAAABaCAMAAAAPdrEwAAAAM1BMVEUAAACPj4+IiIiIiIiIiIiIiIiKioqHh4eHh4eHh4eHh4eIiIiIiIiJiYmIiIiJiYmIiIi8awvKAAAAEHRSTlMAEEDw4NAwwKAgYICQULBwL0wVnQAAAmpJREFUWMPtmOmO4yAQhLlvMO//tDuyjfAaCEcj7UqTT5o/iafSVLcLY/TldyHID8fPH94oir2TLD6QyugdxVoeazAnYPUaFtsws+yNVjR+htolcWz/luHyhL7F55XNQ0Narx+L8TY8bSGTXsiYUB5V8A+zHJ4rud+p3GI+PiwqCXv0Ec+T42awf3L8+iMtzwwp36UEPHR1SIYPKueS+xxJe1CZiYkooNmTvjLHUzHDR7TVgnI2UXR9k/OhQHslieKCcb87reRnB5fCzMeTVp5cUbeY8O6arEYknYs60CJXK21zOvot7DSK4lrR51eA7dQ1y1bFF9MT2Chb358DsLHeLJeKhpZdDgkDFp1jQtRGXiEYOtZU1PLdUt7OFT84gnJUHNE5XOCO2PLnCALDzl21HD2Yam4ZRU9kER8Qs/V7IQ7BIWVqp10TTCFN0gdgwvumJmkcwWDFgigsQtv4Sv8baZ2lt5Pn+n+Wfm+CMsUsHFIJQ7VH+l2hSXsaHFUbEb1l2GRt5zFb/FC1nSfskGam+lSP4cqmks10jyOc1fditiGMXD1G4DekTH5sf14gkTeD1QOdbrRLXodGAKb1hC7gh5nmvzvgI0NoHyswA1niP7WKQE4dmtYHDH4MwzxS3T2MmCWje5OL2aK26j9EC7qkrVIk97XtrM+RYzSoHSZmUCTlLoLNvTs+aFLug+XEu2Mt59boRl9+4vk7gbD79fXnii2dsS6Xc4lb3fx5lX1bfKfPD1HJInetS64lJQnxhkrryV2+INbxeCHXN1PtaGxClUYgvGJ1XY82IA7Fn7IyFO7DIDcYfflN/AFNdjdeDj7M+wAAAABJRU5ErkJggg=='
  45. },
  46. fixed: {
  47. type: Boolean,
  48. default: true
  49. }
  50. }
  51. };
  52. </script>
  53. <style scoped>
  54. .tui-loading {
  55. display: flex;
  56. align-items: center;
  57. justify-content: center;
  58. }
  59. .tui-loading__fixed{
  60. top: 50%;
  61. left: 50%;
  62. transform: translate(-50%, -50%);
  63. z-index: 9999;
  64. }
  65. .tui-loading__box {
  66. min-width: 200rpx;
  67. min-height: 200rpx;
  68. max-width: 500rpx;
  69. flex-direction: column;
  70. border-radius: 10rpx;
  71. }
  72. .tui-loading__ani {
  73. width: 64rpx;
  74. height: 64rpx;
  75. margin: 0 6px;
  76. animation: rotate 0.9s linear infinite;
  77. margin-bottom: 30rpx;
  78. }
  79. .tui-loading__row {
  80. width: 100%;
  81. height: 36rpx;
  82. color: #888;
  83. }
  84. .tui-loading-row__ani {
  85. width: 36rpx;
  86. height: 36rpx;
  87. display: block;
  88. border-radius: 50%;
  89. animation: rotate 0.9s linear infinite;
  90. margin-right: 20rpx;
  91. }
  92. .tui-loading__text {
  93. font-size: 26rpx;
  94. line-height: 26rpx;
  95. text-align: center;
  96. }
  97. @-webkit-keyframes rotate {
  98. from {
  99. transform: rotatez(0deg);
  100. }
  101. to {
  102. transform: rotatez(360deg);
  103. }
  104. }
  105. @keyframes rotate {
  106. from {
  107. transform: rotatez(0deg);
  108. }
  109. to {
  110. transform: rotatez(360deg);
  111. }
  112. }
  113. </style>