From ffb5cf79a2d5d7603cb97e79bd04f598eceb0352 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期四, 20 三月 2025 10:41:29 +0800
Subject: [PATCH] 测试完成

---
 src/views/sfstatistics/analyse/index.vue |  132 +++++++++++++++++++++++++++++++++++++++----
 1 files changed, 119 insertions(+), 13 deletions(-)

diff --git a/src/views/sfstatistics/analyse/index.vue b/src/views/sfstatistics/analyse/index.vue
index c4b52eb..7356406 100644
--- a/src/views/sfstatistics/analyse/index.vue
+++ b/src/views/sfstatistics/analyse/index.vue
@@ -5,7 +5,14 @@
       <div class="value">
         <el-form ref="form" :model="form" label-width="120px">
           <el-form-item label="閫夋嫨鎸囨爣鍚嶇О">
-            <el-select v-model="value" filterable placeholder="璇烽�夋嫨">
+            <el-select
+              remote
+              :remote-method="remoteMethod"
+              default-first-option
+              v-model="value"
+              filterable
+              placeholder="璇烽�夋嫨"
+            >
               <el-option
                 v-for="item in options"
                 :key="item.value"
@@ -19,19 +26,30 @@
       </div>
     </div>
     <div class="formindex">
-      <el-table :data="tableData" border style="width: 100%">
-        <el-table-column prop="date" label="鎸囨爣鍚嶇О"> </el-table-column>
-        <el-table-column prop="name" label="鍗曢」鍚嶇О"> </el-table-column>
-        <el-table-column prop="address" label="鍗曢」鍑虹幇娆℃暟"> </el-table-column>
-        <el-table-column prop="times" label="鎸囨爣鍑虹幇娆℃暟">
+      <el-table
+      v-loading="loading"
+        :data="tableData"
+        :span-method="objectSpanMethod"
+        border
+        :summary-method="getSummaries"
+        show-summary
+        style="width: 100%"
+      >
+        <el-table-column prop="targetname" label="鎸囨爣鍚嶇О"> </el-table-column>
+        <el-table-column prop="targetShowCount" label="鎸囨爣鍑虹幇娆℃暟"> </el-table-column>
+        <el-table-column prop="matchedtext" label="鍗曢」鍚嶇О"> </el-table-column>
+        <el-table-column prop="count" label="鍗曢」閫変腑娆℃暟"> </el-table-column>
+        <el-table-column prop="percentage" label="鍗犳瘮">
+          <template slot-scope="scope">
+            <span>{{ (Number(scope.row.percentage)*100).toFixed(2) }}%</span>            </template>
         </el-table-column>
-        <el-table-column prop="proportion" label="鍗犳瘮"> </el-table-column>
       </el-table>
     </div>
   </div>
 </template>
 
 <script>
+import { gettargetInfo, Labelstatistics } from "@/api/AiCentre/index";
 export default {
   name: "indexanalysis",
   data() {
@@ -56,29 +74,117 @@
           name: "鏈�",
           address: 1,
           times: 2,
-          proportion: "50%",
+          proportion: "50",
         },
         {
           date: "鍙戠儹鏈夋棤",
           name: "鏃�",
           address: 1,
           times: 2,
-          proportion: "50%",
+          proportion: "50",
         },
         {
           date: "鍙戠儹鏈夋棤",
           name: "鍏朵粬",
           address: 0,
           times: 2,
-          proportion: "0%",
+          proportion: "0",
         },
       ],
+      queryParams: {
+        pageNum: 1,
+        pageSize: 66,
+      },
     };
   },
 
-  created() {},
+  created() {
+    this.getList();
+  },
 
-  methods: {},
+  methods: {
+    getList() {
+      this.loading = true;
+      gettargetInfo(this.queryParams).then((res) => {
+        this.targetList = res.rows;
+        this.Labelstatistics(res.rows[0].id)
+      });
+    },
+    Labelstatistics(id){
+      Labelstatistics(id).then((res) => {
+        this.tableData = res.data;
+        this.loading = false;
+      });
+    },
+    remoteMethod(value) {
+      const illnessqueryParams = {
+        pageNum: 1,
+        pageSize: 66,
+        tagname: value,
+      };
+      setTimeout(() => {
+        gettargetInfo(this.illnessqueryParams).then((res) => {
+        this.targetList = res.rows;
+      });
+      }, 200);
+    },
+    objectSpanMethod({ row, column, rowIndex, columnIndex }) {
+      if (columnIndex === 0 || columnIndex === 1) {
+        const totalRows = this.tableData.length;
+        if (rowIndex === 0) {
+          return [totalRows, 1];
+        } else {
+          // 鍏朵粬琛岄殣钘�
+          return [0, 0];
+        }
+      }
+    },
+    getSummaries(param) {
+      const { columns, data } = param;
+      const sums = [];
+      columns.forEach((column, index) => {
+        console.log(data, "data");
+
+        if (index === 0) {
+          sums[index] = "鍚堣"; // 淇敼涓衡�滃悎璁♀�濇洿绗﹀悎璇箟
+          return;
+        }
+        if (column.property === "percentage") {
+          // 瀵瑰崰姣斿垪杩涜鐗规畩澶勭悊
+          const values = data.map((item) => Number(item[column.property]));
+          const total = values.reduce((prev, curr) => {
+            const value = Number(curr);
+            if (!isNaN(value)) {
+              return prev + value;
+            } else {
+              return prev;
+            }
+          }, 0);
+          sums[index] = `${total*100}%`; // 鐩存帴娣诲姞鐧惧垎鍙�
+        } else if (column.property === "targetShowCount") {
+          sums[index] = data[0].targetShowCount + " 娆�"; // 涓烘鏁扮浉鍏冲垪娣诲姞鍗曚綅
+        } else {
+          const values = data.map((item) => Number(item[column.property]));
+          if (!values.every((value) => isNaN(value))) {
+            sums[index] = values.reduce((prev, curr) => {
+              const value = Number(curr);
+              if (!isNaN(value)) {
+                return prev + curr;
+              } else {
+                return prev;
+              }
+            }, 0);
+            if (column.property === "count") {
+              sums[index] += " 娆�"; // 涓烘鏁扮浉鍏冲垪娣诲姞鍗曚綅
+            }
+          } else {
+            sums[index] = "/";
+          }
+        }
+      });
+      return sums;
+    },
+  },
 };
 </script>
 
@@ -89,7 +195,7 @@
     0 0 6px 0 rgba(0, 0, 0, 0.04);
   margin: 15px;
   .title-top {
-    background-color: #00bbd3;
+    background-color: #6784f2;
     color: #fff;
     padding: 10px 20px;
     font-size: 20px;

--
Gitblit v1.9.3