当前位置:首页 > VUE

Vue中table实现CheckBox

2026-02-22 09:27:00VUE

Vue中实现Table的CheckBox功能

在Vue中为表格添加CheckBox功能,可以通过以下方式实现。这里以Element UI的el-table为例,原生表格的实现逻辑类似。

基础实现

定义表格数据时,为每行添加一个selected属性用于绑定CheckBox状态:

data() {
  return {
    tableData: [
      { id: 1, name: '张三', selected: false },
      { id: 2, name: '李四', selected: false }
    ]
  }
}

在模板中使用el-table-column渲染CheckBox列:

<el-table :data="tableData">
  <el-table-column width="50">
    <template #default="{ row }">
      <el-checkbox v-model="row.selected" />
    </template>
  </el-table-column>
  <el-table-column prop="name" label="姓名" />
</el-table>

全选功能实现

添加表头CheckBox实现全选功能:

Vue中table实现CheckBox

<el-table :data="tableData" @select-all="handleSelectAll">
  <el-table-column width="50">
    <template #header>
      <el-checkbox v-model="selectAll" @change="toggleSelectAll" />
    </template>
    <template #default="{ row }">
      <el-checkbox v-model="row.selected" @change="updateSelectAll" />
    </template>
  </el-table-column>
  <!-- 其他列 -->
</el-table>

对应的JavaScript逻辑:

data() {
  return {
    selectAll: false
  }
},
methods: {
  toggleSelectAll(val) {
    this.tableData.forEach(item => {
      item.selected = val
    })
  },
  updateSelectAll() {
    this.selectAll = this.tableData.every(item => item.selected)
  }
}

获取选中项

添加方法获取当前选中的行数据:

Vue中table实现CheckBox

methods: {
  getSelectedRows() {
    return this.tableData.filter(row => row.selected)
  }
}

性能优化

对于大数据量的表格,使用计算属性优化选中状态判断:

computed: {
  selectedCount() {
    return this.tableData.filter(item => item.selected).length
  },
  isIndeterminate() {
    return this.selectedCount > 0 && this.selectedCount < this.tableData.length
  }
}

在模板中使用这些计算属性:

<el-checkbox
  v-model="selectAll"
  :indeterminate="isIndeterminate"
  @change="toggleSelectAll"
/>

原生表格实现

不使用UI框架时,原生实现方式:

<table>
  <thead>
    <tr>
      <th><input type="checkbox" v-model="selectAll" @change="toggleSelectAll"></th>
      <th>姓名</th>
    </tr>
  </thead>
  <tbody>
    <tr v-for="(item, index) in tableData" :key="index">
      <td><input type="checkbox" v-model="item.selected" @change="updateSelectAll"></td>
      <td>{{ item.name }}</td>
    </tr>
  </tbody>
</table>

JavaScript逻辑与上述Element UI示例类似。

标签: Vuetable
分享给朋友:

相关文章

Vue gitbook 实现

Vue gitbook 实现

Vue 与 GitBook 集成实现 将 Vue 集成到 GitBook 中可以通过插件或自定义构建流程实现,以下是具体方法: 使用 gitbook-plugin-vue 插件 安装插件到 GitB…

实现vue table

实现vue table

实现 Vue 表格的基础方法 使用 Vue 实现表格功能可以通过原生 HTML 表格结合 Vue 的数据绑定,或者使用第三方组件库(如 Element UI、Vuetify)快速构建。以下是几种常见方…

Vue实现音乐列表

Vue实现音乐列表

Vue 实现音乐列表的方法 数据准备与绑定 在 Vue 中实现音乐列表,首先需要准备音乐数据。可以通过数组形式存储音乐信息,例如歌曲名称、歌手、封面图片和播放链接。数据可以存储在组件的 data 属性…

Vue项目实现rem

Vue项目实现rem

Vue 项目中实现 rem 适配方案 在 Vue 项目中实现 rem 适配,主要目的是让页面元素根据屏幕尺寸自动调整大小。以下是几种常见方法: 使用 postcss-pxtorem 插件 安装 po…

Vue实现过期退出

Vue实现过期退出

Vue实现过期退出功能的方法 在Vue应用中实现过期退出功能通常涉及以下步骤: 设置登录状态和过期时间 在用户登录成功后,将token和过期时间存储在本地存储或Vuex中: localStora…

Vue实现滚动字幕

Vue实现滚动字幕

Vue实现滚动字幕的方法 使用CSS动画实现 通过CSS的@keyframes和transform属性实现水平滚动效果,结合Vue的动态绑定控制内容。 <template> <…