elementUI中table点击高亮当前行的两种方式

1、highlight-current-row

设置css:

    tr.current-row > td,
    .el-table__body tr:hover > td {
      background: #f5f5f5;
    }

 

2、:row-class-name="tableRowClassName",需要借助@row-click="handleRowClick"获取当前点击行的下标

data中定义:

  data() {
    return {
      tableRowIndex: 0
    }
  }

methods中定义tableRowClassName函数:

    handleRowClick(row) {
      this.tableRowIndex = this.getArrayIndex(this.tableData, row); // 获取当前点击行下标
    // ... 点击当前行,进行的操作
}, tableRowClassName({ row, rowIndex }) { if (rowIndex === this.tableRowIndex) { return 'highlight-row' } return '' }, // 获取一个元素在数组中的下标 getArrayIndex(arr, obj) { var i = arr.length; while (i--) { if (arr[i] === obj) { return i; } } return -1; }

设置css:

    tr.highlight-row td {
      background-color: #fffbe0;
      color: #06aea6;
    }

 

这两种方法的区别:

  需求:设置初始化时第一行高亮

  第一种方法需要设置一个类名定义好样式,默认为true即显示,当点击任一行时将该类设置为false即不显示;第二种方法只需在data中定义tableRowIndex的初始值为0,即默认展示第一条,当点击任一行时,由handleRowClick()方法记录下当前行的下标。

 

x

posted @ 2020-11-12 09:31  吴小明-  阅读(7165)  评论(0编辑  收藏  举报