更新数据
This commit is contained in:
@ -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]"
|
|
||||||
> </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>
|
||||||
|
@ -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;
|
||||||
|
Reference in New Issue
Block a user