ElementUI2.0组件库el-table表格组件如何自定义表头?

问题概述

鼠标移动到el-table表格组件的表头显示提示信息,也算是自定义表头的一种吧。

效果图:(宝宝不会做动图,宝宝心里苦!!!尴尬


1. ElementUI2.0组件库el-table表格组件常规用法

先贴上ElementUI2.0组件库的官网地址:http://element-cn.eleme.io/#/zh-CN ,百度搜索“element”第一个就是啦。

平常使用el-table表格组件是这样的:


1.   给表格传参,tableData是一个数组。

tableData = [
  {date: '2018-01-01',tradeCount: 200, tradeSum: 100}, 
  {date: '2018-01-01', tradeCount: 200,tradeSum: 100}
]

2.   在<el-table-column>中用prop属性来对应对象中的键名即可填入数据。

3.   用label属性来定义表格的列名。可以使用width属性来定义列宽。

4.   表格组件中默认文本居左显示。align=”right”属性可设置文本向右显示,当然还有 left、 center 等属性值。

5.   若想在单元格中自定义,要用<template>标签包裹起来,slot-scope属性传参,scope.row取值。

6.   添加事件。

2. render-header属性了解一下

我们不能直接在prop属性直接传递一个组件或者html元素。正确的做法是:Table组件提供了render-header属性,可以好好利用一番。

这是官网对render-header属性的描述


3. 解决办法--JSX语法

1.   在<el-table-column>中传入render-header属性

<el-table-column align="right" :render-header="renderHeader">
    <template slot-scope="scope">{{scope.row.collected}}</template>
</el-table-column>

2.   在methods自定义renderHeader方法,return (<div></div>)属于渲染函数 & JSX语法中的JSX语法,详见官网 https://cn.vuejs.org/v2/guide/render-function.html#JSX

renderHeader(h, { column, $index }){
  return (
    <div>
        <span>实收总金额(元) </span>
        <el-tooltip class="item" effect="dark" content="实收总金额 = 收款总金额 - 退款总金额"  placement="bottom">
          <i class="el-icon-warning table-msg"></i>
        </el-tooltip>
    </div>
  )
}

3.   npm run dev 编译项目之后,报错,要使用jsx语法需要先安装编译插件

4. 安装JSX语法编译工具

npm install\
  babel-plugin-syntax-jsx\
  babel-plugin-transform-vue-jsx\
  babel-helper-vue-jsx-merge-props\
  babel-preset-es2015\
  --save-dev

5. 配置.babelrc文件

{
  "presets": ["es2015"],
  "plugins": ["transform-vue-jsx"]
}

4. 解决办法--渲染函数

可直接使用渲染函数,不使用JSX语法,就不需要安装额外的编译插件啦

renderHeader(h, data) {
    return h("div", [
        h("span", ['实收总金额(元) ']),
        h("el-tooltip", {
            attrs: {
                class: "item",
                effect: "dark",
                content: "实收总金额 = 收款总金额 - 退款总金额",
                placement: "bottom"
            }
        }, [
            h("i", {
                'class': 'el-icon-warning table-msg'
            })
        ])
    ])
}
h 作为 createElement 的别名是 Vue 生态系统中的一个通用惯例,实际上也是 JSX 所要求的,如果在作用域中 h 失去作用, 在应用中会触发报错



猜你喜欢

转载自blog.csdn.net/qq_32614411/article/details/80880785