ant design 中实现表格头部可删除和添加
我是用antd pro做一个项目。有一个小需求是表格头部栏可操作。具体是表头的每一项都带一个“x”按钮,当不想展示这一栏的时候,直接点“x”,这一栏就不展示了。不展示的头部标签放一边,也可以随时加入到表格中。
先看图:
1.表头信息有个“x”,当点击了某一项,该项在表格中消失,并且该标签会在可添加表头上展示。
2.此时我“x”掉了序号,用户名两项,得到下面的效果。
3.此时我点击了 “+用户名” 标签,表格中再次展示了用户名,同时,可添加表头栏少了 “+用户名” 标签。
这项功能在ant design 上的表格组件是没有的,所以我自己在现有组件的基础上实现的。如果你想看懂下面的代码,你需要了解ant design 的表格组件的使用。
import React from 'react';
import { connect } from 'dva';
import GridContent from '@/components/PageHeaderWrapper/GridContent';
import {
Table,
Card,
Form,
Input,
Button,
Tag,
Select,
Row,
Col,
DatePicker,
message,
Tooltip,
Icon,
} from 'antd';
import { ABNORMAL_AUDIT_STATUS, ABNORMAL_AUDIT_STATUS_COLOR } from '@/constants';
import moment from 'moment'; const { Option } = Select;
const { RangePicker } = DatePicker; const FormItem = Form.Item;
const risk = ['无', '低', '中', '高', '严重'];
@connect(({ riskEvent, abnormalList, loading }) => ({
riskEvent,
abnormalList,
loading: loading.models.abnormalList,
}))
@Form.create()
class AbnormalList extends React.Component {
constructor(props) {
super(props);
this.state = {
selectedData: [],
newCol: [],
colKey: {
id: 0,
username: 1,
riskLevel: 2,
riskScene: 3,
department: 4,
createTime: 5,
status: 6,
baseInfo: 7,
operatePlatform: 8,
},
columns: [
{
title: (
<div>
<a onClick={() => this.columsControl('id')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
序号
</div>
),
dataIndex: 'id',
key: '序号',
},
{
title: (
<div>
<a onClick={() => this.columsControl('username')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
用户名
</div>
),
dataIndex: 'username',
key: '用户名',
},
{
title: (
<div>
<a onClick={() => this.columsControl('riskLevel')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
风险等级
</div>
),
dataIndex: 'riskLevel',
key: '风险等级',
sorter: true,
sortDirections: ['descend'],
render: text => risk[text],
},
{
title: (
<div>
<a onClick={() => this.columsControl('riskScene')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
风险场景
</div>
),
dataIndex: 'riskScene',
key: '风险场景',
render: riskScene => {
const isLong = riskScene.length > 10;
return (
<span>
{isLong ? (
<Tooltip title={riskScene}>`${riskScene.slice(0, 10)}...`</Tooltip>
) : (
<span>{riskScene}</span>
)}
</span>
);
},
},
{
title: (
<div>
<a onClick={() => this.columsControl('department')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
部门
</div>
),
dataIndex: 'department',
key: '部门',
render: dep => {
const isLong = dep.length > 10;
return (
<span>
{isLong ? (
<Tooltip title={dep}>`${dep.slice(0, 10)}...`</Tooltip>
) : (
<span>{dep}</span>
)}
</span>
);
},
},
{
title: (
<div>
<a onClick={() => this.columsControl('createTime')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
告警时间
</div>
),
dataIndex: 'createTime',
key: '告警时间',
},
{
title: (
<div>
<a onClick={() => this.columsControl('status')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>{' '}
状态
</div>
),
dataIndex: 'status',
key: '状态',
render: status => (
<Tag color={ABNORMAL_AUDIT_STATUS_COLOR[status]}>{ABNORMAL_AUDIT_STATUS[status]}</Tag>
),
},
{
title: (
<div>
<a onClick={() => this.columsControl('baseInfo')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>
文件名
</div>
),
dataIndex: 'baseInfo',
key: '文件名',
render: text => {
const jsonData = JSON.parse(text);
const name = jsonData.filename;
return name ? <span>{name}</span> : '';
},
},
{
title: (
<div>
<a onClick={() => this.columsControl('operatePlatform')}>
<Icon style={{ fontSize: '6px' }} type="close" />
</a>
操作平台
</div>
),
dataIndex: 'operatePlatform',
key: '操作平台',
},
{
title: '操作',
fixed: 'right',
width: 80,
render: (_, record) => (
<div>
{record.status === 0 ? (
<RoamMoudle onOk={this.pushRoma}>
<a
onClick={() => {
this.roamId(record.id);
}}
>
流转
</a>
</RoamMoudle>
) : (
<span>流转</span>
)}
</div>
),
},
],
};
} componentWillMount() {
const { dispatch } = this.props;
dispatch({
type: 'abnormalList/fetchList',
payload: {
page: 1,
pageSize: 10,
filter: [],
},
});
} columsControl = str => {
const { colKey, columns, newCol } = this.state;
const id = colKey[str];
newCol.push(columns[id]);
delete columns[id]; // 此处用delete方便后续添加某项表头的时候能回到最开始的位置
this.setState({ columns, newCol });
}; addCol = (one, str, i) => {
const { colKey, columns, newCol } = this.state;
const id = colKey[str];
columns.splice(id, 1, one); // 替换
newCol.splice(i, 1); // 删除
this.setState({ columns, newCol });
}; handleTableChange = (pagination, filters, sorter) => {
const { current, pageSize } = pagination;
const {
dispatch,
abnormalList: { filter },
} = this.props;
dispatch({
type: 'abnormalList/fetchList',
payload: {
page: current,
pageSize,
filter,
sorter,
},
});
}; render() {
const { abnormalList, loading } = this.props;
const { selectedData, columns, newCol } = this.state; const { data, page, total } = abnormalList; const rowSelection = {
onChange: (selectedRowKeys, selectedRows) => {
console.log(`selectedRowKeys: ${selectedRowKeys}`, 'selectedRows: ', selectedRows);
this.setState({ selectedData: selectedRowKeys });
},
getCheckboxProps: record => ({
disabled: record.name === 'Disabled User', // Column configuration not to be checked
name: record.name,
}),
}; return (
<GridContent>
<Card bordered={false}>
<div
style={{
border: '1px solid #CAE7FD',
padding: '5px 10px',
borderRadius: '4px',
background: '#E9F7FE',
}}
>
可添加表头:
{newCol.map((item, index) => (
<Tag key={item.dataIndex}>
<a
onClick={() => {
this.addCol(item, item.dataIndex, index);
}}
>
+{item.key}
</a>
</Tag>
))}
</div>
<br />
<Table
columns={columns}
dataSource={data}
loading={loading}
rowSelection={rowSelection}
scroll={{ x: 1300 }}
rowKey="id"
pagination={{
showSizeChanger: true,
current: page,
total,
pageSizeOptions: ['10', '20', '50', '100'],
}}
onChange={this.handleTableChange}
/>
</Card>
</GridContent>
);
}
} export default AbnormalList;
主要是在columns 中的title中添加点击事件。columsControl,addCol两个函数是实现的关键。
转载请说明来源,谢谢
ant design 中实现表格头部可删除和添加的更多相关文章
- Ant Design中根据用户交互展示不同的标签
Ant Design中根据用户交互展示不同的标签 Ant Design使用的是React框架,那么我们先看代码: <Fragment> <a onClick={() => th ...
- Ant Design中getFieldDecorator方法的特殊用法(小bug)
记录Ant Design中getFieldDecorator方法的特殊的一个用法 了解Ant Design表单的小伙伴都知道,getFieldDecorator在大部分情况下是用来绑定一个控件的,即像 ...
- 如何在cmd命令行中查看、修改、删除与添加环境变量,语法格式例子:set path;echo %APPDATA%
如何在cmd命令行中查看.修改.删除与添加环境变量 首先明确一点: 所有的在cmd命令行下对环境变量的修改只对当前窗口有效,不是永久性的修改.也就是说当关闭此cmd命令行窗口后,将不再起作用.永久性修 ...
- Word2010中的页眉怎样删除和添加横线
http://jingyan.baidu.com/article/f79b7cb3bb3c629144023e05.html 我们在使用Word2010编辑文档中时,有时需要在页眉下方删除或添加一条横 ...
- React之ant design的table表格序号连续自增
render(text,record,index){ return( <span>{(pagination.current-1)*10+index+1}</spa ...
- ant design 中的 Select 组件常规写法
1.代码 import { Select, Spin } from 'antd'; const Option = Select.Option; <Select allowClear showSe ...
- Ant Design中的Form组件
1. 使用Form.create()包裹过的组件可以获取到this.props.form属性 Form.create()(Comp) 2. getFieldDecorator() // 在表单中的使用 ...
- js实现表格信息的删除和添加
制作一个表格,显示班级的学生信息. 要求: 1. 鼠标移到不同行上时背景色改为色值为 #f2f2f2,移开鼠标时则恢复为原背景色 #fff 2. 点击添加按钮,能动态在最后添加一行 3. 点击删除按钮 ...
- Windows 如何在cmd命令行中查看、修改、删除与添加环境变量
转自:http://www.cnblogs.com/saptechnique/archive/2013/02/17/2914222.html 首先明确一点: 所有的在cmd命令行下对环境变量的修改只对 ...
随机推荐
- 统计数字问题(Java)
Description 一本书的页码从自然数1 开始顺序编码直到自然数n.书的页码按照通常的习惯编排,每个页码都不含多余的前导数字0.例如,第6 页用数字6 表示,而不是06 或006 等.数字计数问 ...
- SpringBoot加载配置文件的几种方式
首先回忆一下在没有使用SpringBoot之前也就是传统的spring项目中是如何读取配置文件,通过I/O流读取指定路径的配置文件,然后再去获取指定的配置信息. 传统项目读取配置方式 读取xml配置文 ...
- [web安全原理分析]-XEE漏洞入门
前言 1 前言 XXE漏洞 XXE漏洞全称(XML External Entity Injection)即xml外部实体注入漏洞,XXE漏洞发生在应用程序解析XML输入时,没有禁止外部实体的加载,导致 ...
- 面试大厂必看!就凭借这份Java多线程和并发面试题,我拿到了字节和美团的offer!
最近好多粉丝私信我说在最近的面试中老是被问到多线程和高并发的问题,又对这一块不是很了解,很简单就被面试官给问倒了,被问倒的后果当然就是被刷下去了,因为粉丝要求,我最近也是花了两天时间 给大家整理了这一 ...
- 在线思维导图Ayoa共享功能使用教程
Ayoa是一个制作思维导图的软件,除了导图制作,小编在使用过程中还发现了一些令人惊喜的功能,这些功能使得Ayoa有了更大的亮点以吸引用户. 下面就为大家简单介绍几个小编认为Ayoa中较为实用的共享功能 ...
- 如何使用OCR编辑器检查和识别文本
ABBYY FineReader 15(Windows系统)中的OCR编辑器能帮助用户对扫描仪或者数码相机获取的图像文件进行自动文本识别,OCR区域绘制等,使这些图像文件能进一步转换为可编辑的格式.其 ...
- 和功能相近的虚拟机软件相比,CrossOver的产品优势有哪些?
很多用户其实并不喜欢虚拟机软件,他们只是想用回熟悉的Windows应用程序,因为苹果系统与许多软件并不兼容.无奈之下,他们只能安装虚拟机软件.可是虚拟机软件大多比较笨重并且也相对复杂一些,在后期维护上 ...
- symfony框架学习
http://mozilla.com.cn/thread-52722-1-1.html安装网页翻译插件 symfony2是基于php的web框架 http://www.chrisyue.com/sym ...
- AtCoder Beginner Contest 178 E - Dist Max 题解(推公式)
题目链接 题目大意 给你n个点(n<=2e5)要你求所有点中两个点最短的曼哈顿距离 曼哈顿距离定义为d(i,j)=|x1-x2|+|y1-y2|. 题目思路 想了很久也没有什么思路,其实就是一个 ...
- 给集合null,filter结果空集合