# 动态的页签 - order: 4 演示添加删除和附加操作。 --- ````jsx import { Tabs, Button, Icon, message } from 'antd'; const TabPane = Tabs.TabPane; let index = 0; const closeStyle = { position: 'absolute', top: 8, right: -9, }; const addStyle = { pointerEvents: 'auto', color: '#2db7f5', position: 'absolute', top: 8, left: 0, marginLeft: -8, }; const Test = React.createClass({ getInitialState() { return { tabs: [{ title: 'title ' + index, content: 'content ' + index, index: index }], activeKey: index.toString() }; }, remove(targetIndex, e) { e.stopPropagation(); let tabs = this.state.tabs; let activeKey = this.state.activeKey; let foundIndex = 0; if(tabs.length === 1) { message.error('仅剩一个,不能删除'); return; } const newTabs = tabs.filter(tab => { if (tab.index !== targetIndex) { return true; } else { foundIndex = targetIndex; return false; } }); if (activeKey === targetIndex) { activeKey = tabs[foundIndex - 1].index; } this.setState({ tabs: newTabs, activeKey }); }, add() { index += 1; this.setState({ tabs: this.state.tabs.concat({ title: 'title ' + index, content: 'content ' + index, index: index, }), activeKey: index.toString(), }); }, onChange(activeKey) { console.log(activeKey); this.setState({ activeKey }); }, render() { const addBtn = ; const operations = ; return ( { this.state.tabs.map(tab => ( {tab.title} }>{tab.content} )) } ); } }); ReactDOM.render(, document.getElementById('components-tabs-demo-add')); ````