更新数据

This commit is contained in:
2025-07-24 17:59:32 +08:00
parent a961f32d93
commit 73fc5e2a00
2 changed files with 23 additions and 46 deletions

View File

@ -1,12 +1,10 @@
<template> <template>
<div style="width: 100%"> <div style="width: 100%" :class="getConfiger.showSelectType === 'radio' ? 'tabBoxRadio' : ''">
<!-- hasChildren要在tableData中定义表示当前行有没有下一级 children要在tableData中定义表示下一级的数据--> <!-- hasChildren要在tableData中定义表示当前行有没有下一级 children要在tableData中定义表示下一级的数据-->
<el-table <el-table
ref="multipleTableRef" ref="multipleTableRef"
:data="tableData" :data="tableData"
@selection-change="handleSelectionChange" @selection-change="handleSelectionChange"
@current-change="handleCurrentChange"
@row-click="singleElection"
:row-key="getConfiger.rowKey" :row-key="getConfiger.rowKey"
:border="getConfiger.border" :border="getConfiger.border"
:default-expand-all="getConfiger.defaultExpandAll" :default-expand-all="getConfiger.defaultExpandAll"
@ -21,23 +19,7 @@
:highlight-current-row="getConfiger.showSelectType === 'radio'" :highlight-current-row="getConfiger.showSelectType === 'radio'"
:row-style="{ height: getConfiger.rowHeight === 'auto' ? getConfiger.rowHeight : getConfiger.rowHeight + 'px'}" :row-style="{ height: getConfiger.rowHeight === 'auto' ? getConfiger.rowHeight : getConfiger.rowHeight + 'px'}"
> >
<el-table-column <el-table-column type="selection" width="55" />
type="selection"
width="55"
v-if="getConfiger.showSelectType === 'checkBox'"
/>
<el-table-column
width="55"
v-else-if="getConfiger.showSelectType === 'radio'"
#default="{ row }"
>
<el-radio
class="radio"
v-model="getConfiger.radioChoose"
:label="row[getConfiger.rowKey]"
>&nbsp;</el-radio
>
</el-table-column>
<el-table-column <el-table-column
type="index" type="index"
label="序号" label="序号"
@ -148,19 +130,16 @@ onMounted(() => {
}); });
// 可选的时候选择的数据 // 可选的时候选择的数据
const handleSelectionChange = (val) => { const handleSelectionChange = (val) => {
emit("chooseData", val); if(getConfiger.showSelectType === 'radio' && val.length > 1){
}; let del_row = val.shift();
// 单选的时候选择的数据 multipleTableRef.value.toggleRowSelection(del_row, false);
const handleCurrentChange = (val) => { currentRow.value = val;
currentRow.value = val; emit("chooseData", val);
emit("chooseData", val); }else{
};
const singleElection = (val) => {
if (getConfiger.showSelectType === "radio") {
getConfiger.radioChoose = val[getConfiger.rowKey];
emit("chooseData", val); emit("chooseData", val);
} }
}; };
// 懒加载数据的方法 // 懒加载数据的方法
const load = (date, treeNode, resolve) => { const load = (date, treeNode, resolve) => {
setTimeout(() => { setTimeout(() => {
@ -184,25 +163,14 @@ const load = (date, treeNode, resolve) => {
function setDefaultChoose() { function setDefaultChoose() {
nextTick(() => { nextTick(() => {
// 多选的默认选中 // 多选的默认选中
if ( if ( props.tableConfiger.defaultSelectKeys?.length > 0 && props.tableConfiger.showSelectType === "checkBox" ) {
props.tableConfiger.defaultSelectKeys?.length > 0 &&
props.tableConfiger.showSelectType === "checkBox"
) {
props.tableData.forEach((item) => { props.tableData.forEach((item) => {
if ( if ( props.tableConfiger.defaultSelectKeys.findIndex( (v) => v === item[props.tableConfiger.rowKey] ) > -1) {
props.tableConfiger.defaultSelectKeys.findIndex(
(v) => v === item[props.tableConfiger.rowKey]
) > -1
) {
multipleTableRef.value.toggleRowSelection(item, true); multipleTableRef.value.toggleRowSelection(item, true);
} }
}); });
// 单选的默认选中 // 单选的默认选中
} else if ( } else if ( props.tableConfiger.defaultSelectKeys && props.tableConfiger.defaultSelectKeys?.length > 0 && props.tableConfiger.showSelectType === "radio" ) {
props.tableConfiger.defaultSelectKeys &&
props.tableConfiger.defaultSelectKeys?.length > 0 &&
props.tableConfiger.showSelectType === "radio"
) {
getConfiger.radioChoose = props.tableConfiger.defaultSelectKeys[0]; getConfiger.radioChoose = props.tableConfiger.defaultSelectKeys[0];
} }
}); });
@ -212,3 +180,12 @@ function setDefaultChoose() {
<style lang = "scss"> <style lang = "scss">
</style> </style>
<style>
.tabBoxRadio .el-checkbox__inner {
border-radius: 50% !important;
}
.tabBoxRadio .el-table__header-wrapper .el-checkbox {
display: none;
}
</style>

View File

@ -12,6 +12,7 @@
:tableConfiger="pageData.tableConfiger" :tableConfiger="pageData.tableConfiger"
@chooseData="chooseData"> @chooseData="chooseData">
<template #sjly="{row}"> <template #sjly="{row}">
{{ row.id }}
<DictTag :tag="false" :value="row.sjly" :options="props.dic.D_GS_RQFJ_LX" /> <DictTag :tag="false" :value="row.sjly" :options="props.dic.D_GS_RQFJ_LX" />
</template> </template>
<template #sffj="{row}"> <template #sffj="{row}">
@ -60,6 +61,7 @@ const pageData = reactive({
tableConfiger: { tableConfiger: {
rowHieght: 61, rowHieght: 61,
showSelectType: "radio", showSelectType: "radio",
rowKey:'id',
haveControls: false, haveControls: false,
loading: false, loading: false,
}, },
@ -70,7 +72,6 @@ const pageData = reactive({
}, },
tableColumn: [ tableColumn: [
{ label: "数据来源", prop: "sjly",showSolt:true}, { label: "数据来源", prop: "sjly",showSolt:true},
{ label: "数据类型", prop: "sjlx"},
{ label: "是否发掘", prop: "sffj",showSolt:true}, { label: "是否发掘", prop: "sffj",showSolt:true},
{ label: "数据时间", prop: "sj", showOverflowTooltip: true,}, { label: "数据时间", prop: "sj", showOverflowTooltip: true,},
{ label: "指向地点", prop: "dd", showOverflowTooltip: true,}, { label: "指向地点", prop: "dd", showOverflowTooltip: true,},
@ -104,7 +105,6 @@ const getList = () =>{
let arr = res.records || []; let arr = res.records || [];
pageData.tableData = arr.map((item,idex)=>{ pageData.tableData = arr.map((item,idex)=>{
item.sjly = dm.value ; item.sjly = dm.value ;
item.id = idex;
return item; return item;
}); });
pageData.pageConfiger.total = res.total; pageData.pageConfiger.total = res.total;