Как отправить форму с помощью диалогового окна 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, закройте диалоговое окно.
Прокомментируйте, если это решит вашу проблему или любые другие детали, которые вы хотите.