mrk*_*rks 7 javascript typescript reactjs formik
我的 React (TypeScript) 应用程序具有以下模型:
interface IProjectInput {
id?: string;
name: string | i18n;
description: string | i18n;
}
Run Code Online (Sandbox Code Playgroud)
export interface i18n {
[key: string]: string;
}
Run Code Online (Sandbox Code Playgroud)
我正在使用Formik并react-bootstrap从以下创建一个新ProjectInput的Form:
import { i18n as I18n, ... } from 'my-models';
interface State {
validated: boolean;
project: IProjectInput;
}
/**
* A Form that can can edit a project
*/
class ProjectForm extends Component<Props, State> {
constructor(props: any) {
super(props);
this.state = {
project: props.project || {
name: {},
description: ''
},
validated: false
};
}
async handleSubmit(values: FormikValues, actions: FormikHelpers<IProjectInput>) {
let project = new ProjectInput();
project = { ...project, ...values };
console.log("form values", values);
// actions.setSubmitting(true);
// try {
// await this.props.onSubmit(project);
// } catch (e) { }
// actions.setSubmitting(false);
}
render() {
const { t } = this.props;
const getCurrentLng = () => i18n.language || window.localStorage.i18nextLng || '';
const init = this.state.project || {
name: {},
description: ''
};
return (
<div>
<Formik
// validationSchema={ProjectInputSchema}
enableReinitialize={false}
onSubmit={(values, actions) => this.handleSubmit(values, actions)}
initialValues={init}
>
{({
handleSubmit,
handleChange,
handleBlur,
values,
touched,
errors,
isSubmitting,
setFieldTouched
}) => {
return (
<div className="project-form">
<Form noValidate onSubmit={handleSubmit}>
<Form.Row>
<Form.Group as={Col} md={{span: 5}} controlId="projectName">
<Form.Label>
{t('projectName')}
</Form.Label>
// Input for ENGLISH text
<Form.Control
type="text"
name="name"
value={(values['name'] as I18n).en}
onChange={handleChange}
/>
// Input for FRENCH text
<Form.Control
type="text"
name="name"
value={(values['name'] as I18n).fr}
onChange={handleChange}
/>
</Form.Group>
Run Code Online (Sandbox Code Playgroud)
所以最后它应该是这样的:
{
"name": {
"en": "yes",
"fr": "oui"
},
"description" : "test",
...
}
Run Code Online (Sandbox Code Playgroud)
我的问题是,name输入的值保持为空。
我试图添加const init = this.state.project || { name: { 'en': '' },myrender或 for my state,但这没有做任何事情。
将您Form.Control的道具更改name为name.en/name.fr
首先,initialValues是一个将被设置并且不会改变的道具,除非你通过 prop enableReinitialize。所以这样做不好,this.state.project || { name: { 'en': '' }因为它只会假设第一个值,它可以是this.state.project或{ name: { 'en': '' },但你永远不会知道。
其次,要解决您的问题,请查看以下文档handleChange:
通用输入更改事件处理程序。这将更新
values[key]where key 是事件发射输入的name属性。如果该name属性不存在,handleChange将查找输入的id属性。注意:这里的“输入”是指所有 HTML 输入。
但是在您中,Form.Control您将name属性作为name="name".
所以它试图更新name而不是例如name.en。
你应该改变
<Form.Control
type="text"
name="name"
value={(values['name'] as I18n).en}
onChange={handleChange}
/>
// Input for FRENCH text
<Form.Control
type="text"
name="name"
value={(values['name'] as I18n).fr}
onChange={handleChange}
/>
Run Code Online (Sandbox Code Playgroud)
到
<Form.Control
type="text"
name="name.en" // correct name
value={(values['name'] as I18n).en}
onChange={handleChange}
/>
// Input for FRENCH text
<Form.Control
type="text"
name="name.fr" // correct name
value={(values['name'] as I18n).fr}
onChange={handleChange}
/>
Run Code Online (Sandbox Code Playgroud)
这里是文档以证明你应该使用name.en,而不是只name。
| 归档时间: |
|
| 查看次数: |
8251 次 |
| 最近记录: |