| | |
| | | <div class="analysis-top"> |
| | | <div class="title-top">查询条件</div> |
| | | <div class="value"> |
| | | <el-form ref="form" :model="form" label-width="120px"> |
| | | <el-form ref="form" :model="queryParams" 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="targetvalue" |
| | | @change="Labelstatistics" |
| | | filterable |
| | | placeholder="请选择" |
| | | > |
| | | <el-option |
| | | v-for="item in options" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | v-for="item in targetList" |
| | | :key="item.id" |
| | | :label="item.targetname" |
| | | :value="item.id" |
| | | > |
| | | </el-option> |
| | | </el-select> |
| | |
| | | </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="proportion" 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> |
| | | </div> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { gettargetInfo, Labelstatistics } from "@/api/AiCentre/index"; |
| | | export default { |
| | | name: "indexanalysis", |
| | | data() { |
| | | return { |
| | | options: [ |
| | | targetList: [ |
| | | { |
| | | value: "选项1", |
| | | label: "发热有无", |
| | |
| | | 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", |
| | | }, |
| | | ], |
| | | targetvalue: "", |
| | | queryParams: { |
| | | pageNum: 1, |
| | | pageSize: 66, |
| | | scriptType: "1", |
| | | }, |
| | | }; |
| | | }, |
| | | |
| | | 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) { |
| | | console.log(id, "id"); |
| | | |
| | | Labelstatistics(id).then((res) => { |
| | | if (res.data.length > 0) { |
| | | this.tableData = res.data; |
| | | } else { |
| | | gettargetInfo({ id: id }).then((res) => { |
| | | console.log(res, "替换展示值"); |
| | | this.tableData = []; |
| | | res.rows[0].targetoptionList.forEach((item) => { |
| | | this.tableData.push({ |
| | | targetname: res.rows[0].targetname, |
| | | targetShowCount:0, |
| | | count:0, |
| | | percentage:0, |
| | | matchedtext:item.targetvalue, |
| | | }); |
| | | }); |
| | | }); |
| | | } |
| | | this.loading = false; |
| | | }); |
| | | }, |
| | | remoteMethod(value) { |
| | | const illnessqueryParams = { |
| | | pageNum: 1, |
| | | pageSize: 66, |
| | | targetname: value, |
| | | scriptType: "1", |
| | | }; |
| | | setTimeout(() => { |
| | | gettargetInfo(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> |
| | | |
| | |
| | | 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; |