element-ui中的表格el-table滚动条样式修改以及textarea样式修改

el-table 滚动条的修改(全是在全局样式中定义)

单独修改elementui 组件滚动条的样式

  // 滚动条的宽度
  /deep/ .el-table__body-wrapper::-webkit-scrollbar {
    width: 6px; // 横向滚动条
    height: 6px; // 纵向滚动条 必写
  }
  // 滚动条的滑块
  /deep/ .el-table__body-wrapper::-webkit-scrollbar-thumb {
    background-color: #ddd;
    border-radius: 3px;
  }


还可以无视组件,直接在全局应用于任何地方(此方法不使用与IE浏览器)

::-webkit-scrollbar {
  width: 6px;
  height: 8px;
  background-color: #ebeef5;
}
::-webkit-scrollbar-thumb {
  // border-radius:2px;
  box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
  background-color: #ccc
}
::-webkit-scrollbar-track{
  box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
  border-radius: 3px;
  background: rgba(255, 255, 255, 1);
}

IE浏览器修改滚动条的样式

html,body 
{
  
    SCROLLBAR-FACE-COLOR:#e8f4ff;        /*立体滚动条凸出部分的颜色*/
    SCROLLBAR-HIGHLIGHT-COLOR:#ffffff;    /*滚动条空白部分的颜色*/
    SCROLLBAR-SHADOW-COLOR:#0066cc;        /*立体滚动条阴影的颜色*/
    SCROLLBAR-ARROW-COLOR:#0066cc;        /*上下按钮上三角箭头的颜色*/
    SCROLLBAR-BASE-COLOR:#FFF0E1;       /*滚动条的基本颜色*/
    SCROLLBAR-DARK-SHADOW-COLOR:#ffffff;/*立体滚动条强阴影的颜色*/
    
    font-size: 9pt;
    color: #003366;
    overflow:auto; /*设置或获取表明当内容超出对象高度或宽度时如何管理对象内容的值。*/

}

以上修改有时候会造成表格头部会有一个缝隙解决代码如下

.tableContent{
  padding: 20px !important;
  background: #ffffff;
  margin-top: 20px;
}
body .el-table th.gutter{
  display: table-cell!important;
}
body .el-table colgroup.gutter{
  display: table-cell!important;
}

一.修改table表格无数据时默认显示文字
官方提供的api
empty-text 空数据时显示的文本内容,也可以通过 slot=“empty” 设置 String — 暂无数据

<el-table
  :data="tableData"
  empty-text="你要想显示文字"
>
  .....
</el-tale>

二.更改提示文字并添加图片
当我们需要更改文字并添加图片,则需要使用 slot=‘empty’ 属性。代码如下:

<el-table
  :data="tableData"
>
  <template slot="empty">
    <img src="https://magpie-pic.oss-cn-shenzhen.aliyuncs.com/c8c6da04dcb6e688749baa046262fe8d.gif" alt="" srcset="">
    <span>没有信息</span>
  </template>
  .....
</el-tale>

三、修改 CSS 信息
我们通过重新 element-ui 样式,然后覆盖掉原来的样式信息,这样可以全局一下子处理样式。只需要修改 el-table__empty-block 样式信息即可,代码如下:

.el-table__empty-block{
  background-image: url("");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 75px;
  margin-top: 25px;
  margin-bottom: 60px;
  span{
    position: relative;
    top: 50px;
  }
}

textarea 组件修改样式或者input组件

.el-textarea__inner, .el-input__inner {
	background-color: transparent !important;
	color: #fff !important;
	...
}

记忆力不好,将来能会看,慢慢回味

Vue Element-UI的vxe-table组件中实现自定义面板并允许手动编辑功能,你可以按照以下步骤操作: 1. 定义组件模板:首先,在你的Vue组件中创建一个新的`template`部分,将表头中的某一列设置为可点击,显示自定义编辑面板。 ```html <template> <vxe-table :data="tableData" :columns="columns"> <!-- ... --> <template v-slot:cell(index, row)="{ $index }"> <!-- 检查是否需要编辑,例如通过row.editable属性 --> <div @click="showEditor($index, row)" v-if="row.editable"> <span>{{ row.value }}</span> <el-dialog v-model="dialogVisible" :title="editTitle" width="400"> <custom-editor :row="row" ref="editor"></custom-editor> <div slot="footer"> <el-button @click="cancelEdit($index)">取消</el-button> <el-button type="primary" @click="saveEdit($index)">保存</el-button> </div> </el-dialog> </div> <!-- ... --> </template> </vxe-table> </template> ``` 2. 实现自定义编辑组件:创建一个名为`custom-editor`的组件,接收`row`数据作为props,并包含所需的输入控件。这个组件可以根据实际需求来定制。 ```html <template> <el-form :model="form"> <!-- 添加你想要的手动编辑字段,如el-input、textarea--> <el-input v-model="form.fieldName" placeholder="请输入内容"></el-input> <!-- ... --> </el-form> </template> <script> export default { props: { row: { type: Object, required: true } }, data() { return { form: { ...this.row }, // 初始值等于原始行数据 dialogVisible: false }; }, methods: { cancelEdit(index) { this.dialogVisible = false; // 如果有其他清理操作,可以在这里进行 }, saveEdit(index) { this.form.fieldName = ...; // 更新保存的数据 // 调整数据库或发送API请求更新表格数据 this.$emit('update:row', index, this.form); this.cancelEdit(index); } } }; </script> ``` 3. 监听表格事件:你需要监听`update:row`或者其他适合的事件来自动更新表格数据。 ```js export default { // ... methods: { showEditor(index, row) { this.editTitle = '编辑'; this.dialogVisible = true; this.$refs.editor.row = row; // 将当前行数据绑定到编辑组件 } // ... }, watch: { // 如果表格数据发生变化,可能需要同步编辑状态 tableData(newData) { newData.forEach((row, index) => { if (row.editable && row === this.tableData[index]) { this.showEditor(index, row); } }); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值