这篇文章主要讲解了“怎么去掉ElementUI Table的hover变色问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么去掉ElementUI Table的hover变色问题”吧!
在自定义Element的时候,有一些自带特效我们不想要,去掉又不知道怎么去掉。
比如Table的hover变色。
其实方法并不是去掉,而是让他看起来不变。
开始↓定义单元格背景色:
<el-table :cell- >
定义单元格hover颜色:
.el-table tbody tr:hover>td { background-color:#f5f5f5 !important }
其实就是让hover颜色跟背景色一样啊
:cell-
函数方法为
setCellStyle({ row, column, rowIndex, columnIndex }) { if (column.label === '当前列表头的名字') { return "background:#e8e8e8;"//可以设置颜色或者边框 } if (columnIndex === 4) { return "background:#e8e8e8;" } else { return "background:#e8e8e8;" } }
在使用ElementUI中的table时,往往会有这样的需求:针对某种状态对table表格中的某一行数据进行高亮显示,但同时又要取消鼠标点击事件和hover对高亮显示的行不受影响。
具体的高亮显示,官网中有文档介绍:可以通过指定 Table 组件的 row-class-name 属性来为 Table 中的某一行添加 class,表明该行处于某种状态。
<el-table v-loading="loading.table" :data="data.list.items" fit :cell- element-loading-text="玩命加载中" element-loading-spinner="el-icon-loading" header-cell-class-name="table-header-cell" @selection-change="handleSelectionChange" border :row-class-name="tableRowClassName"> <el-table-column type="selection" width="55"> </el-table-column> <el-table-column label="项目编号" align="center" prop="id" min-width="100"> </el-table-column> <el-table-column label="项目名称" align="center" prop="xmmc" min-width="150"> </el-table-column> <el-table-column label="计划开工日期" align="center" prop="jhkgrq" min-width="150"> <template slot-scope="scope"> {{ scope.row.jhkgrq | dateFormart('yyyy-MM-dd') }} </template> </el-table-column> <el-table-column label="计划竣工日期" align="center" prop="jhjgrq" min-width="150"> <template slot-scope="scope"> {{ scope.row.jhjgrq | dateFormart('yyyy-MM-dd') }} </template> </el-table-column> <el-table-column label="项目地址" align="center" prop="xmwz" min-width="150" :show-overflow-tooltip='true'> </el-table-column> <el-table-column label="项目所属区域" align="center" prop="qymc" min-width="150"> </el-table-column> <el-table-column label="是否竣工" align="center" prop="sfjg" min-width="120" :formatter="stateFormat"> </el-table-column> <el-table-column label="操作" align="center" prop="state" min-width="240"> <template slot-scope="scope"> <el-button icon="el-icon-search" size="mini" type="success" @click="lookHandler(scope.$index, scope.row)">查看 </el-button> <i v-if="scope.row.sfjg==1"> <el-button icon="el-icon-edit" size="mini" type="success" :disabled="true" @click="editHandler(scope.$index, scope.row)"> 编辑 </el-button> </i> <i v-else> <el-button icon="el-icon-edit" size="mini" type="success" @click="editHandler(scope.$index, scope.row)"> 编辑 </el-button> </i> </template> </el-table-column> </el-table>
颜色标记处理:
tableRowClassName({ row, rowIndex }) { if (row.sfjg == 1) { return "success-row"; } else if (row.sfjg == 0) { return "warning-row"; } else { return ""; } },
在全局样式中定义高亮颜色显示
/*列表的表头*/ .table-header-cell { background-color:#8bd2c2!important; color: #fff; font-weight: 400; } .el-table .success-row { background: #ffb707!important; } .el-table .warning-row { background: #def6f6; }
这样就完成了某一行的高亮显示,取消鼠标事件和hover对高亮显示的行影响,我的列表(只作为数据展示)是取消了highlight-current-row 是否要高亮当前行 这个属性,就正常了。
因为:row-class-name="tableRowClassName"在渲染表格的时候就调用了,不能用来响应点击事件改变行的颜色。
或者可以给表格增加:highlight-current-row属性,高亮显示当前行,然后通过修改css样式来改变颜色:
定义响应事件
.el-table__body tr.current-row>td { background: #ffb707!important; }
定义hover事件
.el-table--enable-row-hover .el-table__body tr:hover > td { background-color: #ffb707!important }
改变不了就融入他们,在hover、鼠标点击事件时让他们的颜色与背景色一样就可以.
感谢各位的阅读,以上就是“怎么去掉ElementUI Table的hover变色问题”的内容了,经过本文的学习后,相信大家对怎么去掉ElementUI Table的hover变色问题这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。