最近开发,记录下el-table组件默认选中数据的方式,后台返回的数据不尽相同,代码里面有注释,可以自己根据不同的值换成自己需要的对应的key
场景1:根据用户选择的不同的id去请求渲染的数据,在渲染出来的数据里面进行数据的默认勾选
场景2:每次渲染的表格不同,所以根据不同id进行一个切换的监听,来调用需要渲染的值和需要勾选的值文章来源:https://www.toymoban.com/news/detail-510440.html
大家注意下格式,我自己手敲上来的,可能大括号有一个不对的,自己在工具里面格式化一下看看,面向过程开发。哈哈,还没封装,有更好的可以随时交流文章来源地址https://www.toymoban.com/news/detail-510440.html
<div v-for='(item,index)in msgList' :key='index'>
<el-table ref=Table :data=item.list @selection-change="change($event,index)" v-loading='loading'>
<el-table-column type='selection'/>
<el-table-column prop='attName' lable='属性名称' show-overflow-tooltip/>
</el-table>
</div>
<script>
data(){
return{
currentId:"",//下拉框选择的数据
loading:false,
msgList:[ //需要在页面循环出3个表格
{
title:"表信息",
list:[],//循环的数据
selection:[],//用户选中的数据
},
{
title:"视图信息",
list:[],//循环的数据
selection:[],//用户选中的数据
},
{
title:"字段信息",
list:[],//循环的数据
selection:[],//用户选中的数据
}
]
}
},
watch:{
currentId:{ //监听下拉框id的变化来调用渲染回显数据
handler(newval){
if(newval){
this.gettabList(newval)
}
}
immediate:true //确认是否以当前的初始值执行一次handler函数
}
},
methods:{
async gettabList(newval){
this.loading=true//遮罩打开
if(newval){ //根据监听条件来获取需要默认选中的数据
let table=''
let views=''
let column=''
await api.queryselect(newval).then(res=>{
if(res.code!==200) return //根据当前最新id来渲染页面,后端返回错误不在向下进行
//后台返回的是字符串这里需要做个字符串转数组的操作,具体需不需要根据返回字段定
table = res.data.table.split(',') //切割成数组
views = res.data.views.split(',')
column = res.data.column.split(',')
})
}
//根据选择id不同获取表渲染的数据
await api. getLst(newval).then(res=>{
if(res.code!==200) return
this.msgList[0].lsit=res.data?.tables || [] //给上面需要循环的表进行相对的赋值操作
this.msgList[0].lsit.forEach(item=>{ //从需要渲染的表里面找到需要默认勾选的值(attId)
if(table.indexOf(item.attId)>=0){
//然后再dom渲染完成后调用对应的表格的toggleRowSelection方法写入默认勾选的值
//this.$refs.Table[0]:这是因为页面渲染了3个表格,this.$refs.Table打印出的是一个数组
//使用this.$refs.Table[0]可以找到对应的表格
this.$nextTick(()=>{
this.$refs.Table[0].toggleRowSelection(item,true)
})
}
})
this.msgList[1].lsit=res.data?.views || []
if(views.indexOf(item.attId)>=0){
this.$nextTick(()=>{
this.$refs.Table[1].toggleRowSelection(item,true)
})
}
})
this.msgList[2].lsit=res.data?.column || []
if(column.indexOf(item.attId)>=0){
this.$nextTick(()=>{
this.$refs.Table[2].toggleRowSelection(item,true)
})
}
})
})
this.loading=false//遮罩关闭
}
}
</script>
到了这里,关于el-table默认选中的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!