Index.vue 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. <template>
  2. <div style="display: flex; flex-direction:column;height: 100vh;">
  3. <!-- 店铺名称 -->
  4. <div style="padding: 10px 16px 10px 16px;">
  5. <div style="display: flex;
  6. justify-content:space-between;
  7. align-items:center;">
  8. <div style="font-size: 20px; font-weight: bold;">
  9. <span>设备</span>
  10. </div>
  11. <div style="line-height: 0px;">
  12. <van-icon name="static/images/icon-search-black.png" size="1.7rem" />
  13. </div>
  14. </div>
  15. </div>
  16. <div class="container" style="overflow-y: auto;flex: 1;">
  17. <van-pull-refresh style="min-height: 100%;" v-model="refreshing" @refresh="onRefresh">
  18. <van-swipe-cell v-for="item in dataList" style="background-color: #fff; margin-bottom: 10px;">
  19. <template #right>
  20. <div style="width: 50px; height: 100%; background-color: red;
  21. display: flex; justify-content:center; align-items: center;">
  22. <div>
  23. <div style="color: #fff; font-weight: bold;">
  24. <span>删除</span>
  25. </div>
  26. </div>
  27. </div>
  28. </template>
  29. <van-cell clickable>
  30. <div style="text-align: left;">
  31. <!-- 第一行 -->
  32. <div style="display: flex; justify-content: space-between; margin-bottom: 5px;">
  33. <div style="color: #000; font-size: 0.9rem;">
  34. <span>{{item.productName}}</span>
  35. </div>
  36. <div>{{ item.createtime }}</div>
  37. </div>
  38. <!-- 第二行 -->
  39. <div style="display: flex; align-items: flex-end; margin-bottom: 20px;">
  40. <div style="color: #000; font-weight: bold;">
  41. <span>{{ item.mac }}</span>
  42. </div>
  43. <div style="margin-left: 5px; margin-bottom: 2px;">
  44. <template v-if="getTimeSpan(item.modifytime) < 1200">
  45. <van-tag round size="medium" type="success">在线</van-tag>
  46. </template>
  47. <template v-else>
  48. <van-tag round size="medium" type="danger">离线</van-tag>
  49. </template>
  50. </div>
  51. </div>
  52. <!-- 第三行 -->
  53. <div style="display: flex; justify-content: space-between;">
  54. <div style="display: flex; color: #000;">
  55. <div>
  56. <van-icon name="static/images/icon-location2.png" size="1.5rem" />
  57. </div>
  58. <div style="margin-left: 3px;">位置</div>
  59. </div>
  60. <div style="display: flex; color: #000;">
  61. <div>
  62. <van-icon name="static/images/icon-log.png" size="1.5rem" />
  63. </div>
  64. <div style="margin-left: 3px;">日志</div>
  65. </div>
  66. <div style="display: flex; color: #000;">
  67. <div>
  68. <van-icon name="static/images/icon-edit.png" size="1.5rem" />
  69. </div>
  70. <div style="margin-left: 3px;">编辑</div>
  71. </div>
  72. </div>
  73. </div>
  74. </van-cell>
  75. </van-swipe-cell>
  76. <!-- 数据提示 -->
  77. <div>
  78. <div v-if="refreshing"></div>
  79. <div v-else-if="dataList.length == 0" style="text-align: center; padding: 20px; color: #ccc;">
  80. <span>暂无数据</span>
  81. </div>
  82. <div v-else-if="isLoading" style="text-align: center; padding: 20px;">
  83. <van-loading type="spinner" color="#1989fa" />
  84. </div>
  85. <div v-else-if="page.pages <= page.pageNum" style="text-align: center; padding: 20px; color: #ccc;">
  86. <span>没有更多了</span>
  87. </div>
  88. <div v-else style="text-align: center; padding: 20px;">
  89. <span @click="clickLoading">点击加载</span>
  90. </div>
  91. </div>
  92. <div style="height: 60px; "></div>
  93. </van-pull-refresh>
  94. <!-- 返回顶部 -->
  95. <van-back-top target=".container" right="5vw" bottom="80px" />
  96. </div>
  97. </div>
  98. </template>
  99. <script setup lang="ts">
  100. import { onMounted, reactive, ref } from 'vue';
  101. // import { useRouter } from 'vue-router'
  102. import { post_promise } from '@/network/axios';
  103. import 'vant/es/toast/style';
  104. // 路由
  105. // const router = useRouter();
  106. // 分页
  107. const page = reactive({
  108. pageNum: 1,
  109. pageSize: 10,
  110. pages: 0,
  111. })
  112. const dataList = ref<any[]>([]);
  113. const refreshing = ref(false);
  114. const isLoading = ref(false);
  115. const finished = ref(false);
  116. // 获取数据
  117. const getData = () => {
  118. console.log('onload.....')
  119. post_promise({url: '/device/search', data: {
  120. size: page.pageSize,
  121. page: page.pageNum,
  122. sort: "createtime",
  123. order: "desc",
  124. keyWord: "",
  125. mac: ''
  126. }})
  127. .then((result) => {
  128. console.log(result)
  129. // 刷新结束
  130. isLoading.value = false;
  131. refreshing.value = false;
  132. // 处理成功结果
  133. if(result.code == 0){
  134. // 下拉刷新时清空列表
  135. const dataArr:any[] = result.data;
  136. const pages = Math.ceil(result.total / page.pageSize);
  137. console.log(pages);
  138. console.log(dataArr)
  139. if(page.pageNum == 1){
  140. dataList.value.splice(0, dataList.value.length);
  141. }
  142. dataList.value.push(...dataArr);
  143. page.pages = pages
  144. console.log(dataList.value, pages)
  145. }
  146. },(result) => {
  147. console.log(result)
  148. isLoading.value = false;
  149. refreshing.value = false;
  150. // 跳转到首页
  151. }).catch((ex) => {
  152. console.log(ex)
  153. isLoading.value = false;
  154. refreshing.value = false;
  155. // 跳转到首页
  156. })
  157. };
  158. const onRefresh = () => {
  159. console.log('onrefresh...')
  160. console.log(refreshing.value)
  161. page.pageNum = 1;
  162. // 清空列表数据
  163. finished.value = false;
  164. // 重新加载数据
  165. // 将 loading 设置为 true,表示处于加载状态
  166. isLoading.value = true;
  167. getData();
  168. };
  169. const getTimeSpan = (time: string) => {
  170. const before = Date.parse(time);
  171. const now = new Date().getTime();
  172. return (now - before) / 1000;
  173. }
  174. // 生命周期
  175. onMounted(() => {
  176. console.log('onMounted');
  177. // const before = Date.parse("2011-10-10 14:48:00");
  178. // const now = Date.parse("2011-10-10 15:08:00");
  179. // console.log(before)
  180. // console.log(now)
  181. // console.log(now - before)
  182. getData();
  183. })
  184. // 点击加载
  185. const clickLoading = () => {
  186. console.log('clickLoading');
  187. page.pageNum++
  188. isLoading.value = true
  189. getData();
  190. }
  191. </script>
  192. <style scoped>
  193. </style>