Как отправить форму с помощью диалогового окна Material UI с помощью ReactJS

Я использовал Material UI Dialog для создания списка форм. В официальном случае:

<Dialog
          title="Dialog With Custom Width"
          actions={actions}
          modal={true}
          open={this.state.open}
        >
          This dialog spans the entire width of the screen.
</Dialog>

действия это:

   const actions = [
      <FlatButton
        label="Cancel"
        primary={true}
        onTouchTap={this.handleClose}
      />,
      <FlatButton
        label="Submit"
        primary={true}
        onTouchTap={this.handleClose}
      />,
    ];

Как я могу создать форму и позволить Dialog отправлять данные моей формы?

------------------------------------------------ОБНОВИТЬ- ----------------------------------------------

Есть еще один ответ:

Добавьте атрибут type и form в кнопку действий диалога:

const actions = [
      <FlatButton
        label="Cancel"
        primary={true}
        onTouchTap={this.handleClose}
      />,
      <FlatButton
        label="Submit"
        primary={true}
        onTouchTap={this.handleClose}
        type="submit"        //set the buttom type is submit
        form="myform"        //target the form which you want to sent 
      />,
    ];

и присвойте идентификатор атрибута форме в диалоговом окне:

<Dialog
          title="Dialog With Custom Width"
          actions={actions}
          modal={true}
          open={this.state.open}
        >
        // here can put child component and the code still work even the form is in the child component
         <div className="deal_form">
          <form id="myform" onSubmit = {this.handleCreate} >
            <TextField value={this.state.staff_number} />
          </form>
        </div>
</Dialog>

Ответ 1

Вы можете поместить форму <form> внутри диалогового окна, но вы также должны поместить свои {действия} внутри формы, а не в свойство actions. Ваша кнопка "Отправить действие" должна иметь тип = "отправить" на нее (тип = "reset" также поддерживается и показан ниже).

jsFiddle: https://jsfiddle.net/14dugwp3/6/

const {
  Dialog,
  TextField,
  FlatButton,
  MuiThemeProvider,
  getMuiTheme,
} = MaterialUI;

class Example extends React.Component {
  constructor(props) {
    super(props);
    this.state = { open: true };
    this.handleClose = this._handleClose.bind(this);
  }

  _handleClose() {
    this.setState({ open: false });
  }

  render() {
    const actions = [
      <FlatButton
        type="reset"
        label="Reset"
        secondary={true}
        style={{ float: 'left' }}
        />,
      <FlatButton
        label="Cancel"
        primary={true}
        onClick={this.handleClose}
        />,
      <FlatButton
        type="submit"
        label="Submit"
        primary={true}
        />,
    ];

    return (
      <Dialog
        title="Dialog With Custom Width"
        modal={true}
        open={this.state.open}
        >
        <form action="/" method="POST" onSubmit={(e) => { e.preventDefault(); alert('Submitted form!'); this.handleClose(); } }>
          This dialog spans the entire width of the screen.
          <TextField name="email" hintText="Email" />
          <TextField name="pwd" type="password" hintText="Password" />
          <div style={{ textAlign: 'right', padding: 8, margin: '24px -24px -24px -24px' }}>
            {actions}
          </div>
        </form>
      </Dialog>
    );
  }
}

const App = () => (
  <MuiThemeProvider muiTheme={getMuiTheme() }>
    <Example />
  </MuiThemeProvider>
);

ReactDOM.render(
  <App />,
  document.getElementById('container')
);

Ответ 2

В атрибуте HTML5 form="" может использоваться как ссылка на любую форму на странице. Таким образом, кнопка получает атрибут form="my-form-id", а форма получает атрибут id="my-form-id".

return (
  <Dialog
    open
    actions={[
      <RaisedButton type="submit" form="my-form-id" label="Submit" />
    ]}
  >
    <form id="my-form-id" onSubmit={handleSubmit(this.onSubmit)}>
      <TextField {...fields.username} floatingLabelText="Username" />
    </form>
  </Dialog>
);

Я использую UI материала v0.20.

Ответ 3

Диалог является компонентом ui материала ui, он не будет автоматически отправлять ваши данные формы, если вы хотите создать форму, определите ее внутри диалогового окна следующим образом:

<Dialog
      title="Dialog With Custom Width"
      actions={actions}
      modal={true}
      open={this.state.open}
    >
      /*CREATE THE FORM UI HERE*/
      <div>Field1</div>
      <div>Field2</div>
      <div>Field3</div>
</Dialog>

Если форма содержит много полей, используйте диалог bool, чтобы сделать контент прокручиваемым autoScrollBodyContent = {true}.

Вы определили функцию this.handleSubmit.bind(this) при нажатии кнопки отправки, внутри этой функции вызовите api и отправьте данные, которые вы хотите отправить, после успешного вызова api, закройте диалоговое окно.

Прокомментируйте, если это решит вашу проблему или любые другие детали, которые вы хотите.