render-header
render-header在官方文档中的介绍是这样的:
修改列标题样式
1.在列标题后面加一个图标。
以element-ui官方文档一个table表格为例,我们在地址的后面加一个定位标志的图标,代码如下:
<template> <el-table :data="tableData2" style="width: 100%" :row-class-name="tableRowClassName"> <el-table-column prop="date" label="日期" width="180"> </el-table-column> <el-table-column prop="name" label="姓名" width="180"> </el-table-column> <el-table-column prop="address" label="地址" :render-header="renderHeader"> // 加入render事件 </el-table-column> </el-table> </template> <style> .el-table .warning-row { background: oldlace; } .el-table .success-row { background: #f0f9eb; } </style> <script> export default { methods: { tableRowClassName({row, rowIndex}) { if (rowIndex === 1) { return 'warning-row'; } else if (rowIndex === 3) { return 'success-row'; } return ''; }, // render 事件 renderHeader (h,{column}) { // h即为cerateElement的简写,具体可看vue官方文档 return h( 'div', [ h('span', column.label), h('i', { class:'el-icon-location', style:'color:#409eff;margin-left:5px;' }) ], ); } }, data() { return { tableData2: [{ date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄', }, { date: '2016-05-04', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄', }, { date: '2016-05-03', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }] } } } </script>
效果如下:
2.在列标题后面添加一个单选框
还是以上面的代码为例,只写关键代码:
... // render 事件 renderHeader (h,{column}) { // h即为cerateElement的简写,具体可看vue官方文档 return h( 'div', [ h('span', column.label), h('el-checkbox',{ style:'margin-left:5px', on:{ change:this.select // 选中事件 } }) ], ); }, // 添加选中事件 select (data) { console.log(data); } ...
效果如下:
3.在表头添加一个Tooltip
我们经常会遇到一些奇怪的需求,但是即使再奇怪我们也不能认输,现在有一个需求,要在列表表题后面添加一个提示,我们开始尝试着做:
还是以上面的代码为例,刚开始我想直接用‘el-tooltip',应该不是很难,然后就是这样:
... renderHeader (h,{column}) { return h( 'div', [ h('span', column.label), h('el-tooltip',[ h('i', { class:'el-icon-question', style:'color:#409eff;margin-left:5px;' }) ],{ content: '这是一个提示' }) ] ); } ...
运行后发现,基本样式出来了,但是提示没有
根据element-ui 关于tooltip的文档,我发现不管是effect, content还是placement对tooltip都不管用,既然硬上不管用,就曲线救国,通过组件的方法,先造个轮子再走路
// 写一个PromptMessage的组件,并全局注册 <template> <div class="tooltip"> <el-tooltip effect="dark" placement="right"> <div slot="content"> // 插槽,可提供多行的提示信息 <p v-for="item in messages" :key="item"> {{item}} </p> </div> <i class="el-icon-question" style="color:#409eff;margin-left:5px;font-size:15px;"></i> </el-tooltip> </div> </template> <script> export default { props:['messages'] }; </script>
然后在render-header事件中使用组件
... renderTip (h,{column}) { return h( 'div',{ style:'display:flex;margin:auto;' }, [ h('span', column.label), h('prompt-message', { props: {messages: ["这是住址信息"]} }) ] ); } ...
这次我们发现,果然造的轮子还是挺不错的
JSX语法
或许你会发现,这个原生的createElement 写起来并不简单,而且很费事,我们也可以采用JSX
的方式,这个在Vue官方文档中有提到
查看文档,可以找到安装使用的方法
安装完成后想要再实现tooltip就简单了
... renderTip (h,{column}) { return ( <el-tooltip class="tooltip" effect="dark" placement="right"> <ul slot="content"> <li>这是第一个提示</li> <li>这是第二个提示<li> </ul> <i class="el-icon-question"></i> </el-tooltip> ); } ...
这样看着很好理解,写起来也很方便
补充:
最近有个需求,需要在每次对el-table的单项进行勾选时,使用@select-change去调取后台接口,更改表格数据。
然而,el-table的selection列有个大bug。
首先,获取后的数据对于el-table的selection列来说,没有字段props可以去接收,这就导致没有数据是选中的,会直接触发@select-change方法,回调参数val为[]。
其次,selection需要使用toggleSelection方法去更改,当更改时,又一次触发@select-change方法,这显然不符合需求。
因此,需要自定义table的表头信息,设置为el-checkbox。
代码如下
// 自定义表头select renderHeader(h, {column, $index}) { return h("span", {}, [ h('el-checkbox',{ props: { checked: this.allchecked }, on:{ change: this.updateAllSelected // 选中事件 } })]); },
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]