Skip to content

zhouran19880120/antd-table-columndragsort

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

antd-table-columndragsort

ant-design的Table组件列拖动排序

image

简介

此插件适用于React,前端UI框架为Ant-Design,可实现Table组件列拖动排序,并存储在浏览器localStorage里。

安装

npm install -s antd-table-columndragsort

使用方法

1. 引用插件

import moveColumn from 'antd-table-columndragsort'

2. 仿照Form组件的Form.create方法,包裹一层moveColumn({options})。例如:

export default withRouter(connect(mapStateToProps, mapDispatchToProps, undefined, {withRef: true})(moveColumn({
	columns: [{
		title: '序号',
		dataIndex: 'id'
	}, {
		title: '名称',
		dataIndex: 'name'
	}],
	listName: 'thisPage'
})(Form.create()(MyPage))));

也可使用ES7装饰器。

options设置:

参数名 格式
columns Array 与antd的Table里的columns参数格式相同
listName String (可选)任意字符串。如需把列顺序存入到localStorage中,则配置此项。注意同项目下各个页面此值不能相同
borderStyle String (可选)拖动列的标识线CSS样式,默认为'solid 1px #1890ff'

经过moveColumn包裹的组件将自带this.props.moveColumn方法。

3. 仿照Form组件的getFieldDecorator使用方法,在页面的Table组件外套一层tableFieldDecorator({options})方法。例如:

{this.props.moveColumn.tableFieldDecorator({
  render: {
    name: (text, record, index) => {
      return this.props.userName;
    }
  }
})(<Table
  dataSource={this.props.data}
  pagination={false}
  rowKey="id"
  loading={this.props.loading}
/>)}

options设置:

参数名 格式
render Object 如果render里不会用到this实例,则无需在此处设置,直接写到moveColumn的options里即可。如果在render里需要读取this,则按照dataIndex分类书写render方法(详见示例)

你无需再在Table组件里设置columns参数。

4. 此时表格列头部即可左右拖动。

About

Ant-Design的Table组件列拖拽排序组件

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published