elementui表格默认选中

本文介绍了如何在ElementUI的Table组件中实现数据加载后的默认选中效果。关键在于使用$nextTick确保数据渲染完成后执行默认选中操作,并通过forEach循环及toggleRowSelection方法实现。示例代码展示了如何在axios模拟的接口数据加载后设置默认选中项。
摘要由CSDN通过智能技术生成

重点:

一般地,我们是用接口返回的数据去渲染elementui的Table表格,而这里如果要实现默认选中的效果,就必须要有一下的条件:

1、一定要接口返回数据之后才进行默认选中的操作,即用
this.$nextTick(function() {...}),在里面进行默认选中的操作;

2、一定要用el-table标签里面的data属性的那个数组去用forEach循环体(试过用for循环不行)中用
this.$refs.****.toggleRowSelection(row,true);实现默认选中

不多说,现在模拟一下场景:

<el-table
      ref="multipleTable"
      :data="tableData"
      tooltip-effect="dark"
      style="width: 100%"
      @selection-change="handleSelectionChange">
      <el-table-column
        type="selection"
        width="55">
      </el-table-column>
      <el-table-column
        label="日期"
        width="120">
        <template slot-scope="scope">{{ scope.row.date }}</template>
      </el-table-column>
      <el-table-column
        prop="name"
        label="姓名"
        width="120">
      </el-table-column>
      <el-table-column
        prop="address"
        label="地址"
        show-overflow-tooltip>
      </el-table-column>
    </el-table>
var app = new Vue({
            el: '#app',
            data: {
              tableData: []
            },
            methods: {
 				getData () {
					//此方法就用来模拟axios
					let that = this;
					axios.post('/user', {
					    firstName: 'Fred',
					    lastName: 'Flintstone'
					  })
					  .then(function (response) {
					    	that.tableData = response.data.table;
					    	that.$nextTick(function() {
								that.toggle(that.tableData);   //建议包装成方法这样扩展性更强
							})
					  })
					  .catch(function (error) {
					    console.log(error);
					  });
				},
				toggle (arr) {
					.....   //逻辑代码
					arr.forEach(item => {
						if(...) {
							this.$refs.multipleTable.toggleRowSelection(item,true);
						}
					});
				}
            }
        })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值