在项目开发中,产品提了这样一个需求:实现表格内每一行之间存在间隙以及渐变效果。具体效果如下图所示:
因为element的table组件默认的是行与行挨着,所以需要更改组件的样式,具体代码如下所示:
::v-deep .el-table__body{
//-webkit-border-horizontal-spacing: 13px; // 水平间距
-webkit-border-vertical-spacing: 13px; // 垂直间距
}
设置这个属性可以实现行与行的间距效果,如果想实现列与列之间的间距效果,可以使用上面那个被注释的属性。如果想同时实现行与列的间隔效果,可以直接使用 border-spacing: 20px 实现
在这里插入图片描述
::v-deep .el-table, .el-table__expanded-cell{
background-color: transparent
}
当设置表格内容区域背景色为透明色时,会出现上图的横线,设置以下代码即可。
::v-deep .el-table::before{
height: 0;
}
在这里设置成当前页面的背景色即可隐藏
::v-deep .el-table th.gutter {
//background: linear-gradient(180deg,#000b1f, #001536 100%) !important;
background: #000E26 !important;
}
这里我首先利用table组件的属性row-class-name,进行动态设置每一行的类名,代码如下:
// 设置隔行变色
tableRowClassName({ rowIndex}) {
if (rowIndex % 2 === 0) {
return 'yellow'
} else {
return 'orange'
}
},
然后对不同的类名设置不同的颜色,代码如下:
::v-deep .yellow
background: linear-gradient(90deg,rgba(31,94,167,0.00) 3%, rgba(31,94,167,0.40) 40%, rgba(31,94,167,0.40) 70%, rgba(31,94,167,0.00) 100%) !important;
}
::v-deep .orange
background: linear-gradient(90deg,rgba(31,94,167,0.00) 3%, rgba(31,94,167,0.20) 50%, rgba(31,94,167,0.20) 70%, rgba(31,94,167,0.00) 100%) !important;
}
::v-deep .el-table__row:hover > td {
background-color: transparent !important;
}
::v-deep .el-table th.is-leaf{
border: none;
font-size: 20px;
font-weight: 400
color: rgba(164,185,211, 0.8);
}