vue+elementui中table实现单选行功能

el-table插件可以选择行,但是只能多选,而项目中有单选的需求。

效果如下图所示,点击行或者点击复选框都可以选中行(高亮,复选框选中),并且每次只选中当前行,之前选中的行清空。点击标题行的复选框则清空选中行。

el-table设置。

html 复制代码
<el-table :data="proList"
          ref="tableRef"
          @row-click="rowClick"
          @select-all="selectAll"
          @select="(selection,row)=>rowClick(row)"
          height="calc(100vh - 120px)"
          :header-cell-style="{background:'#F5F9FB ',color:'#333'}"
          border>
    <el-table-column type="selection" width="50" align="center">
    </el-table-column>
    <el-table-column prop="id" label="项目id" align="center">
    </el-table-column>
    <el-table-column prop="projectName" label="项目名称" align="center">
    </el-table-column>
    <el-table-column prop="createTime" label="创建时间" align="center">
    </el-table-column>
</el-table>

函数。其中,selectedRows是自定义的一个数组,用于放置选中的行对象信息,以便在项目中其他地方使用。

javascript 复制代码
/**
 * table行点击事件
 */
rowClick(row, column, event) {
    this.selectedRows = []
    this.$refs.tableRef.clearSelection()
    this.selectedRows.push(row)
    this.$refs.tableRef.toggleRowSelection(row)
},

/**
 * 选择所有checkbox点击事件
 */
selectAll(selection) {
    this.$refs.tableRef.clearSelection();
    this.selectedRows = []
}

有问题评论区回复。。。。能解决的回复。。。。不能解决的自己百度哈。。。。。

相关推荐
duanyuehuan几秒前
|| ?. ?? ??= 4种操作符
前端·javascript·vue.js
前端 贾公子5 分钟前
commitlint安装和配置使用教程
前端
指尖跳动的光5 分钟前
DNS协议
前端·网络
xkxnq9 分钟前
第一阶段:Vue 基础入门(第 8 天)
前端·vue.js·flutter
研☆香12 分钟前
html界面的树形菜单介绍与制作
前端·microsoft·html
星辰也为你祝福h13 分钟前
前端面试题-CSS篇
前端·css
雨雨雨雨雨别下啦16 分钟前
ajax和axios到底是什么
前端·ajax·okhttp
hxjhnct19 分钟前
CSS的模块化
前端·css
qq_4019673821 分钟前
element-plus table组件 封装列隐藏功能,并非 v-if 或 v-for,通过tableRef 与样式控制
javascript·vue.js·elementui
web小白成长日记22 分钟前
Vue3+ElementUI树形菜单:构建层次化用户界面
前端·microsoft·ui·面试·elementui