首页 前端知识 vue elementui el-table表格 点击单元格添加选中样式

vue elementui el-table表格 点击单元格添加选中样式

2024-08-21 22:08:09 前端知识 前端哥 330 846 我要收藏

注意:
1、点击某行单元格添加选中样式;
2、表格第一列数据单独添加样式,比如:加粗;
3、表格表头添加样式,比如:修改背景色;

先上代码(效果图在文章末尾):

<template>
  <div>
    <el-table 
      size="small"
      style="width: 100%;"
      highlight-current-row
      :header-cell-style="headerCellStyle()"
      :cell-class-name="tableCellClassName"
      row-key="index"
      @cell-click="cellclick"
      :cell-style="cellStyle"
      :row-class-name="rowClassName"
      :data="tableData" 
      >
      <el-table-column
        label="名称1"
        prop="name1"
        align="left">
        <template slot-scope="scope">
          <span>{{ scope.row.name1}}</span>
        </template>
      </el-table-column>
      <el-table-column
        label="名称2"
        prop="name2"
        align="center">
        <template slot-scope="scope">
          <span>{{ scope.row.name2 || '-'}}</span>
        </template>
      </el-table-column>
      <el-table-column
        label="名称3"
        prop="name3"
        align="center">
        <template slot-scope="scope">
          <span>{{ scope.row.name3 || '-'}}</span>
        </template>
      </el-table-column>
      <el-table-column
        label="名称4"
        prop="name4"
        align="center">
        <template slot-scope="scope">
          <span>{{ scope.row.name4 || '-'}}</span>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

<script>
export default {
  name: '',
  components: {},
  props: {},
  data () {
    return {
      tableData: [
        {
          name1: '上海',
          name2: 'bbb',
          name3: 'ccc',
          name4: 'ddd',
        },
        {
          name1: '广州',
          name2: 'bb',
          name3: 'cc',
          name4: 'dd',
        },
        {
          name1: '厦门',
          name2: 'b',
          name3: 'c',
          name4: 'd',
        },
        {
          name1: '北京',
          name2: 'bbbb',
          name3: 'cccc',
          name4: 'dddd',
        }
      ],
      cellClickRow:'',
      cellClickColumn: '',
    }
  },
  created () {},
  mounted () {},
  computed: {},
  watch: {},
  methods: {
    // 表头样式
    headerCellStyle () {
     return {
      color: " #333 !important", 
      backgroundColor: "#cedff3  !important",
      fontSize: '14px',
      fontWeight: 500,
     }
    },
    rowClassName ({row,rowIndex}) {
      // 点击时 添加小手样式
      if (rowIndex === 2) {
        return 'addPointer'
      }
    },
    tableCellClassName ({row,column,rowIndex,columnIndex}) {
      // 给行列索引赋值
      row.index = rowIndex
      column.index = columnIndex
      if (columnIndex === 0) {
        return 'columnFirstStyle'
      } else {
        return 'columnOtherStyle'
      }
    },
    cellclick (row, column, cell,event) {
      let clickRanking = '' // 当前点击数据
        for(let i in row) {
          if (i === column.property) {
           clickRanking = row[i]
        }
      }
        // 点击厦门行:点击的厦门数据不为空 且 '厦门' 标题不可点击
        if (row.name1 === '厦门' && clickRanking && clickRanking !=='厦门') {
          this.cellClickRow = row.index
          this.cellClickColumn = column.index
        }
    },
    cellStyle ({row, column, rowIndex, columnIndex}) {
      if (row.name1 === '厦门') {
        // 给所点击的 单元格添加样式
        if (row.index === this.cellClickRow && column.index === this.cellClickColumn) {
          return "border:1px solid #409eff; color:#2C89E5;font-weight: 700;"
        } else {
          return ''
        }
      }
    },


  },
}
</script>

<style lang="scss" scoped>
::v-deep .columnFirstStyle{
  font-weight: 700;
  font-size: 14px;
  color: black;
}
::v-deep .columnOtherStyle{
  font-size: 14px;
}
::v-deep .addPointer{
  cursor: pointer;
}
  
</style>

展示效果图:
在这里插入图片描述

转载请注明出处或者链接地址:https://www.qianduange.cn//article/16465.html
标签
评论
发布的文章

安装Nodejs后,npm无法使用

2024-11-30 11:11:38

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!