Element Plus el-table 默认勾选行的方法

方法一:使用 row-keyreserve-selection

javascript 复制代码
<template>
  <el-table
    ref="multipleTableRef"
    :data="tableData"
    style="width: 100%"
    @selection-change="handleSelectionChange"
    row-key="id"  <!-- 必须指定row-key -->
  >
    <el-table-column type="selection" width="55" :reserve-selection="true" />
    <el-table-column prop="date" label="Date" width="180" />
    <el-table-column prop="name" label="Name" width="180" />
    <el-table-column prop="address" label="Address" />
  </el-table>
</template>

<script setup>
import { ref, onMounted } from 'vue'

const multipleTableRef = ref()
const tableData = ref([
  {
    id: 1,
    date: '2016-05-03',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    id: 2,
    date: '2016-05-02',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    id: 3,
    date: '2016-05-04',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  }
])

// 默认选中的行ID
const defaultSelectedIds = [1, 3]

onMounted(() => {
  // 遍历表格数据,找到需要默认选中的行
  tableData.value.forEach(row => {
    if (defaultSelectedIds.includes(row.id)) {
      // 使用toggleRowSelection方法选中行
      multipleTableRef.value.toggleRowSelection(row, true)
    }
  })
})

const handleSelectionChange = (val) => {
  console.log('当前选中:', val)
}
</script>

方法二:使用 selectselect-all事件

javascript 复制代码
<template>
  <el-table
    ref="multipleTableRef"
    :data="tableData"
    style="width: 100%"
    @select="handleSelect"
    @select-all="handleSelectAll"
    row-key="id"
  >
    <el-table-column type="selection" width="55" />
    <!-- 其他列 -->
  </el-table>
</template>

<script setup>
import { ref, onMounted } from 'vue'

const multipleTableRef = ref()
const tableData = ref([...]) // 同上

onMounted(() => {
  // 默认选中ID为1和3的行
  const rowsToSelect = tableData.value.filter(row => [1, 3].includes(row.id))
  rowsToSelect.forEach(row => {
    multipleTableRef.value.toggleRowSelection(row, true)
  })
})

const handleSelect = (selection, row) => {
  console.log('选中变化:', selection)
}

const handleSelectAll = (selection) => {
  console.log('全选变化:', selection)
}
</script>

方法三:使用 v-model 绑定选中数据

javascript 复制代码
<template>
  <el-table
    :data="tableData"
    style="width: 100%"
    row-key="id"
    @selection-change="handleSelectionChange"
  >
    <el-table-column
      type="selection"
      width="55"
      v-model="selectedRows"
      :reserve-selection="true"
    />
    <!-- 其他列 -->
  </el-table>
</template>

<script setup>
import { ref, onMounted, watch } from 'vue'

const tableData = ref([...]) // 同上
const selectedRows = ref([])

// 设置默认选中的行
onMounted(() => {
  selectedRows.value = tableData.value.filter(row => [1, 3].includes(row.id))
})

const handleSelectionChange = (val) => {
  console.log('选中变化:', val)
}
</script>

方法四:分页表格保留选中状态

javascript 复制代码
<template>
  <el-table
    ref="multipleTableRef"
    :data="currentPageData"
    style="width: 100%"
    row-key="id"
    @selection-change="handleSelectionChange"
  >
    <el-table-column type="selection" width="55" :reserve-selection="true" />
    <!-- 其他列 -->
  </el-table>
  <el-pagination
    @current-change="handleCurrentChange"
    :current-page="currentPage"
    :page-size="pageSize"
    :total="total"
  />
</template>

<script setup>
import { ref, computed } from 'vue'

const multipleTableRef = ref()
const tableData = ref([...]) // 所有数据
const currentPage = ref(1)
const pageSize = ref(10)
const selectedRows = ref([])

const total = computed(() => tableData.value.length)
const currentPageData = computed(() => {
  const start = (currentPage.value - 1) * pageSize.value
  const end = start + pageSize.value
  return tableData.value.slice(start, end)
})

// 默认选中某些行
onMounted(() => {
  const defaultSelectedIds = [1, 3, 5]
  selectedRows.value = tableData.value.filter(row => defaultSelectedIds.includes(row.id))
})

const handleCurrentChange = (page) => {
  currentPage.value = page
}

const handleSelectionChange = (val) => {
  selectedRows.value = val
}
</script>
相关推荐
我是小路路呀23 分钟前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
程序员爱钓鱼29 分钟前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder36 分钟前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
JIngJaneIL1 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
敲敲了个代码1 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_1 小时前
列表渲染(v-for)
前端·javascript·vue.js
JustHappy2 小时前
「chrome extensions🛠️」我写了一个超级简单的浏览器插件Vue开发模板
前端·javascript·github
Loo国昌2 小时前
Vue 3 前端工程化:架构、核心原理与生产实践
前端·vue.js·架构
sg_knight2 小时前
拥抱未来:ECMAScript Modules (ESM) 深度解析
开发语言·前端·javascript·vue·ecmascript·web·esm