zoukankan      html  css  js  c++  java
  • element-ui自定义table表头,修改标题样式、添加tooltip及 :render-header使用简介

    修改列标题样式
    1.在列标题后面加一个图标。

    以element-ui官方文档一个table表格为例,我们在地址的后面加一个定位标志的图标,代码如下:

    <template>
      <el-table
        :data="tableData2"
        style=" 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>
    <script>
    export default {
      methods: {
        // 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: '这是一个提示'
                })
            ]
        );
    }          

    运行后发现,基本样式出来了,但是提示没有,效果如下:

    这样肯定不能满足我们的要求,后来经过自己不断的尝试,发现这样写就可以了

     

    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;'
                     })
                ],{
                    content: '这是一个提示'
                })
            ]
        );
    }        

     

  • 相关阅读:
    C/C++,彩色图像小游戏。
    js 调用百度地图,并且定位用户地址,显示省市区街,经纬度
    C/C++ 双精度double 数据相加出错缺陷解释
    辗转相除法求最大公约数,非goto
    如何用 js 获取table 或者其他块状标签的 宽和高
    如何用 ajax 连接mysql数据库,并且获取从中返回的数据。ajax获取从mysql返回的数据。responseXML分别输出不同数据的方法。
    C++ 连接数据库的入口和获取列数、数据
    Win10:如何修改双网卡的优先级?
    如何拉动内需,击中客户深层需求,4个经典案例分析!
    单点登录SSO简介
  • 原文地址:https://www.cnblogs.com/jmwlhj/p/11004378.html
Copyright © 2011-2022 走看看