/ant-data-table

Ant editable table, A React table component.

Primary LanguageJavaScript

ant-data-table

一个可编辑表格插件。

这里记录了一些关于创建此组件的想法

Live Demo | 演示地址。

参数说明文档。

Basic Example

import React, {Component} from 'react';
import {notification, Button} from 'antd';

import AntEditableTable from '../src/AntEditableTable';

class BasicExample extends Component {

  constructor(props) {
    super(props);
    this.state = {
      dataSource: [{
        key: '1',
        name: '胡彦斌',
        age: 32,
        date: null,
        credit: 3,
        level: 0,
        city: null,
        address: '西湖区湖底公园1号'
      }, {
        key: '2',
        name: '胡彦祖',
        age: 42,
        date: null,
        credit: 5,
        level: 0,
        city: null,
        address: '西湖区湖底公园1号'
      }]
    };
  }

  handleTableData() {
    console.info(this.tableInstance.getDataSource());
    notification.open({
      message: 'Table Data',
      description: JSON.stringify(this.tableInstance.getDataSource()),
      style: {
        width: 600,
        marginLeft: 335 - 600
      }
    });
  }

  handleOnRowSave(index, oldRecord, newRecord) {
    console.info(index, oldRecord, newRecord);
  }

  handleOnDelete(index) {
    const {dataSource} = this.state;
    this.setState({
      dataSource: dataSource.filter((item, idx) => idx !== index)
    });
  }

  handleAddRow() {
    const {dataSource} = this.state;
    dataSource.push({
      key: dataSource.length + 2,
      name: '胡彦祖',
      age: 42,
      date: null,
      credit: 5,
      level: 0,
      city: null,
      address: '西湖区湖底公园1号'
    });
    this.setState(dataSource);
  }

  render() {
    const {dataSource} = this.state;

    const columns = [{
      title: '姓名',
      dataIndex: 'name',
      key: 'name'
    }, {
      title: '年龄',
      dataIndex: 'age',
      editable: {
        type: 'number'
      },
      key: 'age'
    }, {
      title: '信用度',
      dataIndex: 'credit',
      editable: {
        type: 'rate',
        style: {fontSize: 14}
      },
      key: 'credit'
    }, {
      title: '等级',
      width: 80,
      dataIndex: 'level',
      editable: {
        type: 'slider'
      },
      key: 'level'
    }, {
      title: '出生日期',
      dataIndex: 'date',
      editable: {
        type: 'date'
      },
      key: 'date'
    }, {
      title: '城市',
      width: 200,
      dataIndex: 'city',
      editable: {
        type: 'select',
        style: {width: 120},
        options: [
          '北京',
          '武汉',
          '天津',
          '重庆'
        ]
      },
      key: 'city'
    }, {
      title: '住址',
      width: 200,
      dataIndex: 'address',
      editable: {
        type: 'textarea'
      },
      key: 'address'
    }, {
      title: '操作',
      operation: true,
      width: 200
    }];

    return (
      <div style={{padding: '20px 100px 20px 100px'}}>
        <Button
          onClick={this.handleTableData.bind(this)}
          type="primary">获取表格所有数据</Button>
        <Button
          onClick={this.handleAddRow.bind(this)}
          className="text-right"
          style={{marginLeft: 15}}
          type="primary">新增一行</Button>
        <h1>Editable Table Demo </h1>
        <AntEditableTable
          ref={(instance) => {
            this.tableInstance = instance;
          }}
          onDelete={this.handleOnDelete.bind(this)}
          onRowSave={this.handleOnRowSave.bind(this)}
          enableRowEdit
          pagination={false}
          data={dataSource}
          columns={columns} />
      </div>
    );
  }
}

export default BasicExample;

依赖 | Dependencies

ant-design