【ElementUI】el-table中复选框禁用处理

文章目录

前言

Vue 项目开发过程中,尤其是后台管理开发,经常会用到 ElementUI 中的表格和表单,有时候我们需要在表格中添加复选框,来实现全选和单选当前行的操作,而这时如果有条件要限制选框是否禁用该如何处理呢?这就需要展开来说了,因为表头全选和表格行中的单个选择处理是不同的。

一、处理body中的复选框禁用

在官方文档 Table-column 中有一回调函数 selectable 用于返回值用来决定这一行的 CheckBox 是否可以勾选,它仅对 type=selection 的列有效。函数有两个参数 Function(row, index):

  • row 当前行相关信息参数
  • index 当前行索引值

设置复选框的 column 代码如下:

c 复制代码
<el-table-column
   type="selection"
   width="60"
   slign="center"
   :selectable="enableSelect">
</el-table-column>

定义这个函数,并添加相关条件

当前是查看详情页面,或者编辑页面的当前行被禁用时不可操作

返回值为 false 不可操作,默认为 true 可操作

c 复制代码
enableSelect(row,index){
	if(this.type == 'detail'){
		return false
	} else if(row.status === 0) {
		return false
	} else {
		return true
	}
}

二、处理head中的复选框禁用

如果想要处理表头上面的复选框禁用,这里可以采用添加样式的方式,将其隐藏处理。这就需要在 el-table 上添加一个属性 header-cell-class-name,属性值可以是一个作为表头单元格的 style 的回调方法,也可以使用一个固定的 Object 为所有表头单元格设置一样的 Style。
Function({row, column, rowIndex, columnIndex})/Object

回调函数解构参数:

  • row
  • column
  • rowIndex
  • columnIndex

template 模板代码:

c 复制代码
<el-table 
	v-loading="loading" 
	:data="tableData" 
	ref="tableRef"
	:header-cell-class-name="cellClassName"
	@selection-change="handleSelectionChange">
 	<el-table-column
	   type="selection"
	   width="60"
	   slign="center"
	   :selectable="enableSelect"/>
    <el-table-column
    	type="index"
    	label="序号"
    	align="center"/>
    .... 
    <el-table-column label="状态" prop="status" align="center"/>
</el-table>

定义函数,指定某些条件下显示的类名

c 复制代码
cellClassName() {
	if(this.type == 'detail') {
		return "cell-disabled"
	} else {
		return ""
	}
}

style 样式隐藏(scss 处理器穿透)

c 复制代码
::v-deep .cell-disabled .cell {
    visibility: hidden;
}
相关推荐
eEKI DAND3 分钟前
一个比 Nginx 还简单的 Web 服务器
服务器·前端·nginx
Highcharts.js7 小时前
Highcharts 云端渲染的真相:交互式图表与服务器端生成的边界
前端·信息可视化·服务器渲染·highcharts·图表渲染
zhuyan1088 小时前
Linux 系统磁盘爆满导致无法启动修复指南
前端·chrome
编程牛马姐8 小时前
独立站SEO流量增长:提高Google排名的优化方法
前端·javascript·网络
NotFound4869 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Dontla9 小时前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
一 乐10 小时前
医院挂号|基于springboot + vue医院挂号管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·医院挂号管理系统
whuhewei11 小时前
为什么客户端不存在跨域问题
前端·安全
妮妮喔妮12 小时前
supabase的webhook报错
开发语言·前端·javascript
yivifu12 小时前
手搓HTML双行夹批效果
前端·html·html双行夹注