ant-design/components/modal/demo/footer.md
2015-07-08 20:53:11 +08:00

1.5 KiB

自定义页脚

  • order: 2

更复杂的例子,自定义了页脚的按钮,点击提交后进入 loading 状态,完成后关闭。


var Modal = antd.Modal;

var Test = React.createClass({
  getInitialState: function() {
    return {
      loading: false,
      visible: false
    };
  },
  showModal() {
    this.setState({ visible: true });
  },
  handleOk() {
    this.setState({ loading: true });
    setTimeout(()=> {
      this.setState({ loading: false, visible: false });
    }, 3000);
  },
  handleCancel() {
    this.setState({ visible: false });
  },
  render() {
    return <div>
      <button className="ant-btn ant-btn-primary" onClick={this.showModal}>
        显示对话框
      </button>
      <Modal ref="modal"
       visible={this.state.visible}
       title="对话框标题" onOk={this.handleOk} onCancel={this.handleCancel}
        footer={[
          <button key="back" className="ant-btn" onClick={this.handleCancel}> </button>,
          <button key="submit" className="ant-btn ant-btn-primary" onClick={this.handleOk}>
             
            <i className={'anticon anticon-loading'+(this.state.loading?'':'hide')}></i>
          </button>
        ]}>
        <p>对话框的内容</p>
        <p>对话框的内容</p>
        <p>对话框的内容</p>
        <p>对话框的内容</p>
        <p>对话框的内容</p>
      </Modal>
    </div>;
  }
});

React.render(<Test/> , document.getElementById('components-modal-demo-footer'));