element-ui--table之选择框改变选中状态或禁止选中

13 篇文章 0 订阅
1 篇文章 0 订阅

1.改变选中状态

官方文档:

表格默认选中:

<template>
	<el-table :data="tableData"  ref="multipleTable" @row-click="handleCurrentChange">
	</el-table>
</template>
<script>
export default {
data(){
	return{
		tableData:[
		{
			id:1,
			name:"111",
            isSelected:true
		},
        {
			id:2,
			name:"222",
            isSelected:false
		},
        ]
	}
},   
mounted() {
 this.tableData.forEach(item => {
   if(item.isSelected){
      this.$refs.multipleTable.toggleRowSelection(item,true);
   }
 });
}
}
</script>

注意:当数据是从后端获取的时候,这样写不能默认选中,此时应写成:

this.$nextTick(function(){
      this.$refs.multipleTable.toggleRowSelection(item,true);
}

2.禁止选中

给选择框那一行加监听事件:selectable="方法"

 <div>
    <el-table
    :data="tableData"
    @selection-change="handleSelectionChange">
    <el-table-column
      type="selection"
      :selectable="checkSelectable"
      width="50">
    </el-table-column>
    <el-table-column
      inline-template
      label="年"
      width="120">
      <div>{{ row.date }}</div>
    </el-table-column>
    <el-table-column
      prop="name"
      label="姓名"
      width="120">
    </el-table-column>
    <el-table-column
      prop="isModify"
      label="是否可以修改"
      show-tooltip-when-overflow>
    </el-table-column>
  </el-table>
  {{ multipleSelection }}
  </div>
export default{
  data() {
    return {
      tableData: [{
          date: '2018',
          name: '小海',
          isModify: '是'
        }, {
          date: '2016',
          name: '小北',
          isModify: '是'
        }, {
          date: '2012',
          name: '小张',
          isModify: '否'
        }, {
          date: '2011',
          name: '小胡',
          isModify: '否'
        }],
        multipleSelection: []
    }
  },
  methods: {
    handleSelectionChange(val) {
      this.multipleSelection = val
    },
    //禁止选中的条件
    checkSelectable(row) {
      return row.isModify=='是'
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值