# 文档

此组件基于element-table二次开发,以实际业务出发,封装了常用的功能,通过配置的方式生成表格, 并且实现多级表头 expand展开项 自定义表头功能等

hpyJmt.png (opens new window)

# 安装

使用之前需要项目中引入element-ui

# npm

npm i vue-jsx-table

import 'vue-jsx-table/dist/vue-jsx-table.css'
import vueJsxTable from 'vue-jsx-table'

Vue.use(vueJsxTable)

# cdn方式

  <!-- 引入样式 -->
    <link
      rel="stylesheet"
      href="https://unpkg.com/vue-jsx-table/dist/vue-jsx-table.css"
    />
    <!-- 引入组件库 -->
    <script src="https://unpkg.com/vue-jsx-table/dist/vue-jsx-table.umd.min.js"></script>

# 普通表格

对于表格配置columns、tableData选项是必须的。

<template>
  <vue-jsx-table
    :columns="columns"
    :show-pagination="false"
    :tableData="tableData"
  >
  </vue-jsx-table>
</template>

<script>
export default {
  name: "demo-1",
  data() {
    return {
      columns: [
        {
          label: "姓名",
          prop: "name3",
        },
        {
          label: "年龄",
          prop: "age",
        },
      ],
      tableData: [
        {
          name: "张三",
          name1: "张三",
          name2: "张三",
          name3: "张三",
          age: 18,
          id: 1,
          school: "一中",
          fee: 2000,
          grade: "高一",
          class: "一班",
        },
        {
          name: "李四",
          name1: "李四",
          name2: "李四",
          name3: "李四",
          age: 19,
          id: 2,
          school: "二中",
          fee: 1000,
          grade: "高二",
          class: "三班",
        },
      ],
    };
  },
  methods: {},
};
</script>

<style lang="scss" scoped></style>

Expand Copy

# 自定义渲染内容 render

给column设置render选项,Funtion(row, column, $index)

     {
          label: 'render',
          prop: 'render',
          width: 200,
          render: (row, column, $index) => {
            return (
              <div onClick={() => this.cellClick(row, column, $index)}>
                测试render
              </div>
            );
          },
        },

# 设置展开项

只需要对column配置项设置type:expand,展开的内容可以使用插槽slot,也可以使用render,如果同时配置slot,render,则slot会被忽略。

{
          type: 'expand',
          slot: 'expand',
        },

# 自定义插槽

只需要对 column配置项设置 solt:'',slot为插槽的名字

  {
          label: '编辑',
          prop: 'edit',
          slot: 'edit',
          fixed: 'right',
          width: 200,
        },

# 自定义表头

只需要对 column配置项设置 renderHeader,renderHeader为element-ui的原生配置 (官方不推荐使用column上的render-header函数,推荐使用插槽 !!,控制台会有提示,,囧),你也可以使通过配置slotHeader项使用插槽,注意插槽名称不能重复,定义了插槽配置已定义在模板中声明

# renderHeader

   {
          label: '自定义表头',
          prop: 'name',
          width: 120,
          sortable: true,
          renderHeader: (column, scope) => {
            console.log('scope', scope);
            return <span class="cell-header-red-star">{column.label}</span>;
          },
        },

# 表头插槽 slotHeader

       {
          label: '姓名',
          prop: 'name',
          slotHeader: 'slotHeader',
        },

         <!-- 插槽表头 -->
        <template v-slot:slotHeader="{ column }">
          <!-- {{ scope.column.label }} -->
          <span>插槽表头: {{ column.label }}</span>
        </template>

# 分页展示

分页控件pageSize 改变、currentPage 改变,都会触发page-change,Function({currentPage,pageSize})

  <vue-jsx-table
        @page-change="pageChangeHandle"
        :currentPage.sync="paginationParams.pageNo"
        :total="100"
      >
  </vue-jsx-table>    
pageChangeHandle(val) {
      this.paginationParams.pageNo = val.currentPage;
      this.paginationParams.pageSize = val.pageSize;
    },

# 表格列内容为组件

通过solt插槽,也可以使用render函数来渲染组件

  <template v-slot:edit="{ row }">
          <el-input v-model="row.name"></el-input>
        </template>

# 完整示例

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 10
共 100 条

<template>
  <div>
    <el-card title="表格1">
      <vue-jsx-table
        :columns="columns"
        :tableData="tableData"
        border
        @page-change="pageChangeHandle"
        :currentPage.sync="paginationParams.pageNo"
        :total="100"
      >
        <!-- expand 插槽 -->
        <template v-slot:expand>
          <vue-jsx-table
            :columns="columns2"
            :tableData="tableData"
            border
            style="width: 700px"
            :showPagination="false"
            @selection-change="selectionChange"
          />
        </template>
        <!-- 自定义插槽 -->
        <template v-slot:edit="{ row }">
          <el-button type="text" @click="editHandle(row)">编辑</el-button>
          <br />
          <el-input v-model="row.name"></el-input>
        </template>
        <!-- 插槽表头 -->
        <template v-slot:slotHeader="{ column }">
          <!-- {{ scope.column.label }} -->
          <span>插槽表头: {{ column.label }}</span>
        </template>
      </vue-jsx-table>
    </el-card>
    <br />
    <el-card title="设置展示字段">
      <el-button type="primary" @click="showGrate">展示年级</el-button>
      <el-button type="primary" @click="hideGrate">隐藏年级</el-button>
      <vue-jsx-table
        :columns="columns3"
        :tableData="tableData"
        border
        :showPagination="false"
        showTableSetting
        :hideColumns="hideColumns"
      />
    </el-card>
  </div>
</template>

<script>
export default {
  name: "index",
  data() {
    return {
      columns: [
        {
          type: "expand",
          slot: "expand",
        },
        {
          label: "姓名+表头红星",
          prop: "name1",
          width: 160,
          cellredstar: true,
        },
        {
          label: "自定义表头",
          prop: "name2",
          width: 120,
          sortable: true,
          renderHeader: (column, scope) => {
            console.log("scope", scope);
            return <span class="cell-header-red-star">{column.label}</span>;
          },
        },
        {
          label: "姓名",
          prop: "name3",
          slotHeader: "slotHeader",
        },
        {
          label: "年龄",
          prop: "age",
          sortable: true,
        },
        {
          label: "多级表头",
          children: [
            {
              label: "年级",
              prop: "grade",
              width: 120,
            },
            {
              label: "班级",
              prop: "class",
              formatter: (row) => {
                return `${row.grade}:${row.class}`;
              },
            },
          ],
        },
        {
          label: "render",
          prop: "render",
          width: 200,
          cellredstar: true,
          render: (row, column, $index) => {
            return (
              <div onClick={() => this.cellClick(row, column, $index)}>
                测试render
              </div>
            );
          },
        },
        {
          label: "学校",
          prop: "school",
          width: 200,
          showHeaderTooltip: true,
          headerTooltipText: "学校tooltipText",
        },
        {
          label: "学费",
          prop: "fee",
          width: 200,
        },

        {
          label: "编辑",
          prop: "edit",
          slot: "edit",
          fixed: "right",
          width: 200,
        },
      ],
      columns2: [
        {
          type: "selection",
          fixed: "left",
          selectable: this.rowSelectableHandle,
        },
        {
          type: "expand",
          render: () => {
            return <div>通过render 函数自定义内容</div>;
          },
        },
        {
          label: "姓名",
          prop: "name",
        },
        {
          label: "年龄",
          prop: "age",
        },
      ],
      tableData: [
        {
          name: "张三",
          name1: "张三",
          name2: "张三",
          name3: "张三",
          age: 18,
          id: 1,
          school: "一中",
          fee: 2000,
          grade: "高一",
          class: "一班",
        },
        {
          name: "李四",
          name1: "李四",
          name2: "李四",
          name3: "李四",
          age: 19,
          id: 2,
          school: "二中",
          fee: 1000,
          grade: "高二",
          class: "三班",
        },
      ],
      columns3: [
        {
          label: "姓名",
          prop: "name",
        },
        {
          label: "年龄",
          prop: "age",
        },
        {
          label: "学校",
          prop: "school",
        },
        {
          label: "学费",
          prop: "fee",
        },
        {
          label: "年级",
          prop: "grade",
        },
        {
          label: "班级",
          prop: "class",
        },
      ],
      paginationParams: {
        pageNo: 1,
        pageSize: 10,
      },
      hideColumns: [],
    };
  },
  methods: {
    selectionChange(val) {
      console.log("val", val);
    },
    cellClick(row, column, index) {
      console.log("cellClick", row, column, index);
    },
    rowSelectableHandle(row) {
      return row.id === 2;
    },
    editHandle(row) {
      console.log("editHandle:row", row);
    },
    pageChangeHandle(val) {
      this.paginationParams.pageNo = val.currentPage;
      this.paginationParams.pageSize = val.pageSize;
    },
    showGrate() {
      this.hideColumns = [];
    },
    hideGrate() {
      this.hideColumns = ["年级"];
    },
  },
};
</script>

<style lang="scss" scoped></style>


Expand Copy

# Table Attributes

所有的Table Attributes通过v-bind="$attrs"实现,额外增加的Table Attributes:

参数 说明 类型 默认值
columns 表格的列 Array []
columnsKeyName column 的 key,如果需要使用 filter-change 事件,则需要此属性标识是哪个 column 的筛选条件(Table-column Attributes的column-key) string -
align 对齐方式 String left
showPagination 是否展示分页控件 Boolean true
currentPage 当前分页控件的当前页 Number 1
pageSizes 分页控件的pageSizes Array [10, 20, 30, 50]
pageSize 分页控件的pageSize Array []
layout 分页控件的layout String 'sizes, prev, pager, next,total'
total 分页控件的total Number 0
paginationStyle 分页控件的样式style Object -
showOverflowTooltip 当内容过长被隐藏时显示 tooltip,如果column没单独配置showOverflowTooltip,则使用该属性,默认为true Boolean true
showTableSetting 展示表格设置 Boolean false
hideColumns 需要隐藏的列,label名称,有些场景需要根据部分条件展示隐藏列 Array []
customClass 自定义样式class Array ['vue-jsx-table-wrapper']

# Table Events

所有的 Table Events 通过v-on="$listeners"实现,额外增加的 Table Events:

参数 说明 类型 默认值
size-change page-change,current-change改变都会触发此事件,为了方便分页改变而增加 Function 'function({pageSize: 10,currentPage: 1,}) {}'
size-change pageSize 改变时会触发 - -
current-change currentPage 改变时会触发 - -

# 配置列 columns

参数 说明 类型 默认值
prop 对应列内容的字段名 string -
slot 列的插槽名字(注意如果嵌套表格,slot名称不能有重复的,插槽作用域({ row, $index })) string -
label 显示的标题 string -
width 对应列的宽度 Number -
showOverflowTooltip 当内容过长被隐藏时显示 tooltip Boolean -
fixed 列是否固定在左侧或者右侧(true, left, right),true 表示固定在左侧 string, boolean -
render jsx渲染函数 function render(row, column, $index)
type selection/index/expand string -
renderHeader 表头,列标题 Label 区域渲染使用的 Function Function(column, scope }),column为配置项,scope为原生组件的scope 。(该属性不是原生参数) -
cellredstar 表头文字前是否打红星标志 Boolean false
sortable 对应列是否可以排序,如果设置为 'custom',则代表用户希望远程排序,需要监听 Table 的 sort-change 事件 boolean, string (true, false, 'custom') false
formatter 用来格式化内容(element-ui原有属性) Function(row, column, cellValue, index) -
selectable 仅对 type=selection 的列有效,类型为 Function,Function 的返回值用来决定这一行的 CheckBox 是否可以勾选 Function(row, index) -
showHeaderTooltip 鼠标移到表头是否展示文案提示信息 Boolean -
headerTooltipText 表头展示文案信息内容 String -