【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;
}
相关推荐
工业互联网专业27 分钟前
毕业设计选题:基于ssm+vue+uniapp的校园水电费管理小程序
vue.js·小程序·uni-app·毕业设计·ssm·源码·课程设计
豆豆41 分钟前
为什么用PageAdmin CMS建设网站?
服务器·开发语言·前端·php·软件构建
计算机学姐1 小时前
基于SpringBoot+Vue的在线投票系统
java·vue.js·spring boot·后端·学习·intellij-idea·mybatis
twins35202 小时前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky2 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~2 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
安冬的码畜日常2 小时前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
杨荧3 小时前
【JAVA开源】基于Vue和SpringBoot的洗衣店订单管理系统
java·开发语言·vue.js·spring boot·spring cloud·开源
l1x1n03 小时前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
昨天;明天。今天。3 小时前
案例-任务清单
前端·javascript·css