V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
kinglisky
V2EX  ›  前端开发

基于 Element UI 表格封装的表格组件

  •  1
     
  •   kinglisky ·
    kinglisky · 2017-10-26 22:53:16 +08:00 · 5463 次点击
    这是一个创建于 2647 天前的主题,其中的信息可能已经有所发展或是发生改变。

    基于 Element UI table 组件封装得表格组件,只为了让你少些几行代码😎。

    项目地址: https://github.com/kinglisky/egrid

    文档地址: http://kinglisky.github.io/egrid

    为什么要在 element table 组件之上再封装一层呢?

    平时我们使用的 element table 时候往往是这样写的:

    <template>
      <el-table
        :data="tableData"
        border
        style="width: 100%">
        <el-table-column
          label="日期"
          width="180">
          <template scope="scope">
            <el-icon name="time"></el-icon>
            <span style="margin-left: 10px">{{ scope.row.date }}</span>
          </template>
        </el-table-column>
        <el-table-column
          label="姓名"
          width="180">
          <template scope="scope">
            <el-popover trigger="hover" placement="top">
              <p>姓名: {{ scope.row.name }}</p>
              <p>住址: {{ scope.row.address }}</p>
              <div slot="reference" class="name-wrapper">
                <el-tag>{{ scope.row.name }}</el-tag>
              </div>
            </el-popover>
          </template>
        </el-table-column>
        <el-table-column label="操作">
          <template scope="scope">
            <el-button
              size="small"
              @click="handleEdit(scope.$index, scope.row)">编辑</el-button>
            <el-button
              size="small"
              type="danger"
              @click="handleDelete(scope.$index, scope.row)">删除</el-button>
          </template>
        </el-table-column>
      </el-table>
    </template>
    

    如果每次使用表格都要重复这一段代码,那久而久之你的项目肯定会冗余很多重复的代码,而且也不利于维护。 这时候我们就有必要在原始的表格组件基础上再封装一层,将这些重复的代码放在组件内部,使用时考虑如何通过一种配置的方式去定制表格。

    我觉得理想表格组使用方式应该是:

    <egrid
      :other="other"
      :data="data"
      :columns="columns">
    </egrid>
    

    data 对应表格的数据源,columns 用于配置表格中各个列的渲染。

    可能有的同学会说,简单的封装我会呀!不是就是 for 渲染几个 el-table-column 的事吗?但是这样的封装后,怎么定义自定渲染内容。

    额,这就是重点了,egrid 就是为了解决这些问题而写的。

    早前是在自己的项目中封装过简单的 element 表格组件,但通用性不强,于是决定重写一版服务一下大家。

    这里就不讲具体的实现,核心的自定义组件依赖 <component> 组件实现的。

    实现其实挺简单的, 源码在这,但 100% 无缝支持 element table 的所有功能。

    文档在这: http://kinglisky.github.io/egrid 小小安利一下。

    第 1 条附言  ·  2017-10-26 23:53:52 +08:00
    1 条回复    2017-10-27 09:27:35 +08:00
    del1214
        1
    del1214  
       2017-10-27 09:27:35 +08:00
    哎呦不错哦
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2200 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 01:18 · PVG 09:18 · LAX 17:18 · JFK 20:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.