element-ui自定义table表头,render-header使用

html 复制代码
<el-table-column header-align="right" align="right" :render-header="renderHeader">
    <el-table-column prop="week" label="日期"></el-table-column>
    <el-table-column prop="name" label="项目"></el-table-column>
</el-table-column>

js部分

javascript 复制代码
renderHeader(h, {column}) {
                return h('el-button', {
                    style: 'margin-top: 2px;', // 样式
                    class: '', 
                    props: { // 标签自定义属性
                        size: 'medium',
                        type: 'success'
                    },
                    on: {
                        click: this.exportExcel, // 选中事件
                    },
                }, '导出');
            },

标签多层嵌套

在表头添加el-tooltip

javascript 复制代码
renderHeader(h, { column }) {
            return h('div', [
                h('span', column.label),
                h(
                    'el-tooltip',
                    {
                        props: {
                            effect: 'dark',
                            content: '这是一个提示',
                            placement: 'top',
                        },
                    },
                    [
                        h('i', {
                            class: 'el-icon-question',
                            style: 'color:#409eff;margin-left:5px;',
                        }),
                    ],
                ),
            ]);
        },

在表头后添加一个单选框

javascript 复制代码
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);
        },
}

其它资料还有这种方式

<el-table-column

prop="date"

label="日期/(生产旺季)"

width="180"

align='center'

:render-header="renderHeader"/>

methods:{

renderHeader(h, { column, $index }) {

let columnArr = column.label.split("/");//此处换行标志

if (columnArr.length >= 2) {

let divArr = [];

columnArr.map((item) => {

if(item == columnArr[0]){

divArr.push(h("div", { style: "text-align: center "}, item));

}else{

divArr.push(h("span", { style:"text-align:right;color:#fc5563;font-size:12px"}, item));

}

});

return h("span", {style:"display: line-block"}, divArr);

}

return h("span", {}, column.label);

},

}

相关推荐
踩着两条虫1 分钟前
如何评价VTJ.PRO?
前端·架构·ai编程
Mh1 小时前
鼠标跟随倾斜动效
前端·css·vue.js
小码哥_常2 小时前
Kotlin类型魔法:Any、Unit、Nothing 深度探秘
前端
Web极客码3 小时前
深入了解WordPress网站访客意图
服务器·前端·wordpress
幺风4 小时前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
vjmap4 小时前
唯杰地图CAD图层加高性能特效扩展包发布
前端·gis
ZC跨境爬虫4 小时前
3D 地球卫星轨道可视化平台开发 Day7(AI异步加速+卫星系列精简+AI Agent自动评论)
前端·人工智能·3d·html·json
ID_180079054734 小时前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A4 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
vipbic4 小时前
独立开发复盘:我用 Uni-app + Strapi v5 肝了一个“会上瘾”的打卡小程序
前端·微信小程序