2025-09-08 11:19:56 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<!-- 右侧表格 -->
|
|
|
|
|
|
<div>
|
|
|
|
|
|
<el-card style="min-height: calc(100vh - 125px)">
|
|
|
|
|
|
<!-- 查询 -->
|
2025-09-11 17:28:45 +08:00
|
|
|
|
<el-form size="small" ref="queryForm" :inline="true" :model="queryParams">
|
2025-09-08 11:19:56 +08:00
|
|
|
|
<el-form-item prop="dataTypeName">
|
2025-09-11 17:28:45 +08:00
|
|
|
|
<el-input clearable placeholder="搜索" v-model="queryParams.dataTypeName"
|
|
|
|
|
|
@keyup.enter.native="onHandleQuery" />
|
2025-09-08 11:19:56 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
|
|
|
|
<el-form-item>
|
2025-09-11 17:28:45 +08:00
|
|
|
|
<el-button size="mini" type="primary" icon="el-icon-search" @click="onHandleQuery">
|
2025-09-08 11:19:56 +08:00
|
|
|
|
查询
|
|
|
|
|
|
</el-button>
|
2025-09-11 17:28:45 +08:00
|
|
|
|
<el-button size="mini" icon="el-icon-refresh" @click="onResetQuery">
|
2025-09-08 11:19:56 +08:00
|
|
|
|
重置
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 表格 -->
|
2025-09-11 17:28:45 +08:00
|
|
|
|
<el-table :data="filteredTableData" border :height="tableHeight" style="width: 100%">
|
|
|
|
|
|
<el-table-column v-if="tableData && tableData.length" type="index" label="序号" width="60" align="center" />
|
|
|
|
|
|
<el-table-column align="center" :key="column.prop" :prop="column.prop" :label="column.label"
|
|
|
|
|
|
v-for="column in columns" />
|
2025-09-08 11:19:56 +08:00
|
|
|
|
</el-table>
|
|
|
|
|
|
</el-card>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
2025-09-11 14:05:59 +08:00
|
|
|
|
import { getListDataSetAPI } from '@/api/data-collect/data-set-manage'
|
2025-09-08 11:19:56 +08:00
|
|
|
|
export default {
|
|
|
|
|
|
name: 'RightTable',
|
|
|
|
|
|
props: {
|
|
|
|
|
|
selectedNodeId: {
|
|
|
|
|
|
type: [Number, String],
|
2025-09-11 14:05:59 +08:00
|
|
|
|
default: 0,
|
2025-09-08 11:19:56 +08:00
|
|
|
|
},
|
|
|
|
|
|
},
|
|
|
|
|
|
data() {
|
|
|
|
|
|
return {
|
|
|
|
|
|
queryParams: {
|
|
|
|
|
|
dataTypeName: undefined,
|
|
|
|
|
|
},
|
|
|
|
|
|
tableData: [],
|
|
|
|
|
|
columns: [],
|
2025-09-11 17:28:45 +08:00
|
|
|
|
tableHeight: 400,
|
|
|
|
|
|
filteredManual: null,
|
2025-09-08 11:19:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
2025-09-11 17:28:45 +08:00
|
|
|
|
computed: {
|
|
|
|
|
|
// 按第二个字段进行本地过滤
|
|
|
|
|
|
filteredTableData() {
|
|
|
|
|
|
// 仅在点击“查询”后使用过滤结果;输入变化不自动过滤
|
|
|
|
|
|
if (Array.isArray(this.filteredManual)) return this.filteredManual
|
|
|
|
|
|
return this.tableData
|
|
|
|
|
|
},
|
|
|
|
|
|
},
|
2025-09-08 11:19:56 +08:00
|
|
|
|
methods: {
|
2025-09-11 17:28:45 +08:00
|
|
|
|
// 查询:按第一列字段做模糊匹配
|
2025-09-08 11:19:56 +08:00
|
|
|
|
onHandleQuery() {
|
2025-09-11 17:28:45 +08:00
|
|
|
|
if (!Array.isArray(this.columns) || this.columns.length < 1) return
|
|
|
|
|
|
const targetProp = this.columns[0] && this.columns[0].prop
|
|
|
|
|
|
if (!targetProp) return
|
|
|
|
|
|
const keyword = String(this.queryParams.dataTypeName || '').trim()
|
|
|
|
|
|
if (!keyword) {
|
|
|
|
|
|
// 空关键字还原
|
|
|
|
|
|
this.filteredManual = null
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
// 执行一次性本地过滤
|
|
|
|
|
|
const source = Array.isArray(this.tableData) ? this.tableData : []
|
|
|
|
|
|
const kw = keyword.toLowerCase()
|
|
|
|
|
|
this.filteredManual = source.filter(row => {
|
|
|
|
|
|
const val = row && targetProp in row ? row[targetProp] : ''
|
|
|
|
|
|
return String(val ?? '').toLowerCase().includes(kw)
|
|
|
|
|
|
})
|
|
|
|
|
|
// 触发一次高度计算,避免数据量变化造成滚动体验不佳
|
|
|
|
|
|
this.computeTableHeight()
|
2025-09-08 11:19:56 +08:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 重置
|
|
|
|
|
|
onResetQuery() {
|
2025-09-11 17:28:45 +08:00
|
|
|
|
this.queryParams = { dataTypeName: undefined }
|
|
|
|
|
|
this.filteredManual = null
|
|
|
|
|
|
this.computeTableHeight()
|
2025-09-08 11:19:56 +08:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 获取数据列表
|
2025-09-11 14:05:59 +08:00
|
|
|
|
async getListDataSetClassFun(node) {
|
2025-09-11 17:28:45 +08:00
|
|
|
|
const params = {
|
|
|
|
|
|
dataClassifyId: node,
|
|
|
|
|
|
}
|
|
|
|
|
|
const res = await getListDataSetAPI(params)
|
|
|
|
|
|
|
|
|
|
|
|
// 安全解析与渲染
|
|
|
|
|
|
this.columns = []
|
|
|
|
|
|
this.tableData = []
|
|
|
|
|
|
if (!res || !Array.isArray(res.rows) || res.rows.length === 0) return
|
|
|
|
|
|
|
|
|
|
|
|
const firstRow = res.rows[0]
|
|
|
|
|
|
if (!firstRow || !firstRow.dataJson) return
|
|
|
|
|
|
|
|
|
|
|
|
let dataList = []
|
|
|
|
|
|
try {
|
|
|
|
|
|
dataList = JSON.parse(firstRow.dataJson)
|
|
|
|
|
|
} catch (e) {
|
|
|
|
|
|
console.warn('数据集 dataJson 解析失败:', e)
|
|
|
|
|
|
return
|
2025-09-08 11:19:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-09-11 17:28:45 +08:00
|
|
|
|
if (!Array.isArray(dataList) || dataList.length === 0) return
|
|
|
|
|
|
|
|
|
|
|
|
const [header, ...rows] = dataList
|
|
|
|
|
|
if (header && typeof header === 'object') {
|
|
|
|
|
|
this.columns = Object.entries(header)
|
|
|
|
|
|
.filter(([prop]) => String(prop).toLowerCase() !== 'id')
|
|
|
|
|
|
.map(([prop, label], index) => ({
|
|
|
|
|
|
label: String(label),
|
|
|
|
|
|
prop: String(prop),
|
|
|
|
|
|
width: index === 0 ? '120' : undefined,
|
|
|
|
|
|
align: index === 0 ? 'left' : 'center',
|
|
|
|
|
|
}))
|
|
|
|
|
|
}
|
|
|
|
|
|
// 将数据行统一转换为对象行,按 columns 的 prop 顺序映射,确保搜索可用
|
|
|
|
|
|
const propOrder = this.columns.map(c => c.prop)
|
|
|
|
|
|
this.tableData = rows.map(row => {
|
|
|
|
|
|
if (Array.isArray(row)) {
|
|
|
|
|
|
const obj = {}
|
|
|
|
|
|
for (let i = 0; i < propOrder.length; i++) {
|
|
|
|
|
|
obj[propOrder[i]] = row[i]
|
|
|
|
|
|
}
|
|
|
|
|
|
return obj
|
2025-09-08 11:19:56 +08:00
|
|
|
|
}
|
2025-09-11 17:28:45 +08:00
|
|
|
|
return row || {}
|
|
|
|
|
|
})
|
|
|
|
|
|
// 数据变更后重新计算高度
|
|
|
|
|
|
this.computeTableHeight()
|
|
|
|
|
|
},
|
|
|
|
|
|
// 计算表格高度(使用固定 height,滚动更顺滑)
|
|
|
|
|
|
computeTableHeight() {
|
|
|
|
|
|
this.$nextTick(() => {
|
|
|
|
|
|
const topOffset = this.$el ? this.$el.getBoundingClientRect().top : 0
|
|
|
|
|
|
const formHeight = this.$refs.queryForm && this.$refs.queryForm.$el
|
|
|
|
|
|
? this.$refs.queryForm.$el.offsetHeight
|
|
|
|
|
|
: 0
|
|
|
|
|
|
// 额外预留:卡片内边距、表格头部等
|
|
|
|
|
|
const extra = 100
|
|
|
|
|
|
const available = window.innerHeight - topOffset - formHeight - extra
|
|
|
|
|
|
this.tableHeight = Math.max(260, available)
|
|
|
|
|
|
})
|
2025-09-08 11:19:56 +08:00
|
|
|
|
},
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 监听选中的节点ID
|
|
|
|
|
|
watch: {
|
|
|
|
|
|
selectedNodeId: {
|
|
|
|
|
|
handler(newVal) {
|
|
|
|
|
|
this.columns = []
|
|
|
|
|
|
this.tableData = []
|
2025-09-11 14:05:59 +08:00
|
|
|
|
this.getListDataSetClassFun(newVal)
|
2025-09-08 11:19:56 +08:00
|
|
|
|
},
|
2025-09-11 14:05:59 +08:00
|
|
|
|
immediate: true, // 表示立即执行
|
2025-09-08 11:19:56 +08:00
|
|
|
|
},
|
|
|
|
|
|
},
|
2025-09-11 17:28:45 +08:00
|
|
|
|
|
|
|
|
|
|
mounted() {
|
|
|
|
|
|
const onResize = () => this.computeTableHeight()
|
|
|
|
|
|
this.computeTableHeight()
|
|
|
|
|
|
window.addEventListener('resize', onResize)
|
|
|
|
|
|
this.$once('hook:beforeDestroy', () => {
|
|
|
|
|
|
window.removeEventListener('resize', onResize)
|
|
|
|
|
|
})
|
|
|
|
|
|
},
|
2025-09-08 11:19:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
</script>
|
2025-09-11 17:28:45 +08:00
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
/* 加粗表格滚动条 */
|
|
|
|
|
|
::v-deep .el-table__body-wrapper::-webkit-scrollbar,
|
|
|
|
|
|
::v-deep .el-table__fixed-body-wrapper::-webkit-scrollbar {
|
|
|
|
|
|
width: 10px; /* 垂直滚动条宽度 */
|
|
|
|
|
|
height: 10px; /* 水平滚动条高度 */
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
::v-deep .el-table__body-wrapper::-webkit-scrollbar-track,
|
|
|
|
|
|
::v-deep .el-table__fixed-body-wrapper::-webkit-scrollbar-track {
|
|
|
|
|
|
background: #f1f1f1;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
::v-deep .el-table__body-wrapper::-webkit-scrollbar-thumb,
|
|
|
|
|
|
::v-deep .el-table__fixed-body-wrapper::-webkit-scrollbar-thumb {
|
|
|
|
|
|
background: #bfbfbf;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
::v-deep .el-table__body-wrapper::-webkit-scrollbar-thumb:hover,
|
|
|
|
|
|
::v-deep .el-table__fixed-body-wrapper::-webkit-scrollbar-thumb:hover {
|
|
|
|
|
|
background: #a6a6a6;
|
|
|
|
|
|
}
|
|
|
|
|
|
</style>
|