script.js 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. // 全局变量定义
  2. let page = 1; // 初始页码为1,代表从第1条数据开始获取
  3. let pageSize = 10; // 初始每次固定获取10条数据
  4. let total = 0; // 数据总量(从接口获取)
  5. let loadedItems = 0; // 已加载的数据条目数量
  6. let isLoading = false; // 防止多次加载
  7. const timeoutDuration = 10000; // 超时时间10秒
  8. const preLoadDistance = 300; // 距离底部300px时提前加载
  9. // 假设 Authorization 值存储在 localStorage 中,key 为 "authToken"
  10. const authToken = localStorage.getItem("Authorization");
  11. // 获取与 license_info 相关的 HTML 元素
  12. const license_info_container = document.getElementById('restaurant-list'); // 卡片列表容器
  13. const license_info_modal = document.getElementById('license-info-modal'); // 模态框容器
  14. const license_info_modalContent = document.querySelector('.license-info-modal-content'); // 模态框内容区域
  15. const license_info_modalTitle = document.getElementById('license-info-modal-title'); // 模态框标题
  16. const license_info_modalDescription = document.getElementById('license-info-modal-description'); // 模态框描述
  17. const license_info_modalPrice = document.getElementById('license-info-modal-price'); // 模态框产品信息
  18. const license_info_modalRating = document.getElementById('license-info-modal-rating'); // 模态框MAC地址
  19. const license_info_closeModal = document.querySelector('.license-info-close'); // 模态框关闭按钮
  20. const license_info_loadingIndicator = document.getElementById('loading-indicator'); // 加载提示元素
  21. const license_info_mainElement = document.querySelector('main'); // 主内容区域
  22. // 获取数据函数
  23. async function fetchLicenseData(page, pageSize) {
  24. try {
  25. const response = await fetch(`http://127.0.0.1:8080/api/admin/GetAllLicenseInfo?page=${page}&pageSize=${pageSize}`, {
  26. method: 'GET',
  27. headers: {
  28. 'Authorization': `Bearer ${authToken}`,
  29. 'Content-Type': 'application/json'
  30. }
  31. });
  32. const result = await response.json();
  33. // 设置总量,如果第一次加载,获取total字段
  34. if (total === 0 && result.total) {
  35. total = result.total;
  36. }
  37. return result.data || []; // 返回获取到的数据,或空数组
  38. } catch (error) {
  39. console.error("加载数据失败", error);
  40. return []; // 返回空数组,防止后续操作出错
  41. }
  42. }
  43. // 渲染 license_info 卡片数据函数
  44. function renderLicenseCards(data, clearContainer = false) {
  45. if (clearContainer) {
  46. license_info_container.innerHTML = ''; // 清空容器内容
  47. }
  48. data.forEach(group => {
  49. const firstItem = group[0]; // 获取该组的第一个数据项
  50. let statusClass = '';
  51. if (firstItem.LicenseFlage === '已生成') {
  52. statusClass = 'license-status-green';
  53. } else if (firstItem.LicenseFlage === '未生成') {
  54. statusClass = 'license-status-yellow';
  55. } else if (firstItem.LicenseFlage === '已失效') {
  56. statusClass = 'license-status-red';
  57. }
  58. const card = document.createElement('div');
  59. card.className = 'license-info-card';
  60. // 在卡片的第一行显示申请时间
  61. card.innerHTML = `
  62. <div class="license-info-card-header">
  63. <h3 class="card-title">${firstItem.GlxmName}</h3>
  64. </div>
  65. <div class="license-info-card-content">
  66. <p class="card-text">${firstItem.ApplicationDate} ${firstItem.ApplicationTime}</p> <!-- 显示日期和时间 -->
  67. <p class="card-text">创建者:${firstItem.Creator}</p>
  68. <p class="card-text">公司:${firstItem.Company}</p>
  69. <p class="card-text ${statusClass}">许可证状态:${firstItem.LicenseFlage}</p>
  70. </div>
  71. `;
  72. // 将卡片添加到容器中
  73. license_info_container.appendChild(card);
  74. });
  75. console.log("卡片渲染完成,准备添加监听器"); // 确保卡片已经渲染
  76. // 确保在渲染完成后调用监听器绑定
  77. addCardClickListeners();
  78. }
  79. // 检查页面是否填满,如果没有则继续加载更多数据
  80. function checkContentHeight() {
  81. const documentHeight = document.documentElement.scrollHeight;
  82. const windowHeight = window.innerHeight;
  83. if (documentHeight <= windowHeight) {
  84. console.log("页面内容不足,继续加载更多数据");
  85. loadMoreData(); // 当内容高度不足时,继续加载更多数据
  86. }
  87. }
  88. // 检查是否滚动到底部并触发加载
  89. async function checkAndLoadMore(scrollHeight, scrollTop, clientHeight) {
  90. if (isLoading || loadedItems >= total) return; // 如果正在加载或已加载完所有数据则退出
  91. console.log(`Scroll Info - scrollHeight: ${scrollHeight}, scrollTop: ${scrollTop}, clientHeight: ${clientHeight}`);
  92. if (scrollTop + clientHeight >= scrollHeight - preLoadDistance) {
  93. console.log(`触发加载更多数据:page=${page}, pageSize=${pageSize}`); // 每次触发时打印输出
  94. await loadMoreData();
  95. }
  96. }
  97. // 加载更多数据函数
  98. async function loadMoreData() {
  99. if (isLoading) return; // 防止重复加载
  100. isLoading = true;
  101. console.log('开始加载更多数据');
  102. // 显示加载提示
  103. // license_info_loadingIndicator.style.display = 'block'; // 显示提示
  104. // license_info_loadingIndicator.innerText = '正在加载...'; // 重置加载提示
  105. // 设置超时处理
  106. const timeout = setTimeout(() => {
  107. license_info_loadingIndicator.innerText = '加载超时,请重试'; // 修改提示语为超时提示
  108. isLoading = false;
  109. license_info_loadingIndicator.style.display = 'none'; // 超时后隐藏加载提示
  110. }, timeoutDuration);
  111. // 获取数据
  112. const data = await fetchLicenseData(page, pageSize);
  113. // 清除超时定时器
  114. clearTimeout(timeout);
  115. if (data.length > 0) {
  116. // 渲染数据到页面
  117. renderLicenseCards(data);
  118. // 更新 page 和 pageSize,下一次请求从新的位置开始
  119. page += 10; // 每次请求后,page 增加10,表示从下一组数据开始
  120. pageSize += 10; // pageSize 每次递增10
  121. // 更新已加载的条目数
  122. loadedItems += data.length;
  123. console.log('数据加载完成,更新页面');
  124. }
  125. // 隐藏加载提示
  126. //license_info_loadingIndicator.style.display = 'none'; // 加载完成后隐藏提示
  127. isLoading = false; // 请求完成,允许下次请求
  128. // 检查内容高度,必要时继续加载
  129. checkContentHeight();
  130. }
  131. // 监听 window 滚动
  132. window.addEventListener('scroll', () => {
  133. checkAndLoadMore(document.body.scrollHeight, window.scrollY, window.innerHeight);
  134. });
  135. // 监听 main 容器的滚动
  136. license_info_mainElement.addEventListener('scroll', () => {
  137. checkAndLoadMore(license_info_mainElement.scrollHeight, license_info_mainElement.scrollTop, license_info_mainElement.clientHeight);
  138. });
  139. // 初始化加载第一页
  140. (async function() {
  141. const data = await fetchLicenseData(page, pageSize);
  142. if (data.length > 0) {
  143. renderLicenseCards(data); // 渲染数据到页面
  144. loadedItems += data.length; // 更新已加载的条目数
  145. }
  146. //license_info_loadingIndicator.style.display = 'none'; // 初始化后隐藏加载提示
  147. // 检查内容高度
  148. checkContentHeight();
  149. })();
  150. //-----------点击卡片弹出模态框------------------------------------------------------