在子组件中使用DropDown的React-Final-Form,如何?

问题描述 投票:0回答:2

我正在尝试在子组件中使用带有DropDown的React-final-form。无法让这个工作。

我的所有文本字段都已存在于子组件中,这就像一个魅力。父级中的字段如下所示:

<Field
    name="lastName"
    placeholder="Last Name"
    validate={required}
>
    {({input, meta, placeholder}) => (
        <MyField meta={meta} input={input} placeholder={placeholder}/>
    )}
</Field>

子组件看起来像这样:

export const MyField = (props) => {
    return (
        <Form.Field className={props.meta.active ? 'active' : ''}>
            <Label>{props.label ? props.label : props.placeholder}</Label>
            <Form.Input
                {...props.input}
                placeholder={props.placeholder}
                className={(props.meta.error && props.meta.touched ? 'error' : '')}
            />
        </Form.Field>
    )
};

“Form.Field”和“Label”来自semantic-ui-react

但现在我想用Drop Down做同样的事情。标准Drop Down,qazxsw大便,看起来像这样:

taken from an example on the React-Final-Form site

从某种意义上说,它在我的react-final-form值中得到了值。然后我试图将Dropdown本身卸载到Child Component(打算使用Dropdown的语义ui-react版本,但首先要做的事情是让Dropdown工作:-))

父组件:

<Field name="toppingsA" component="select">
    <option value="chicken">Chicken</option>
    <option value="ham">Ham</option>
    <option value="mushrooms">Mushrooms</option>
    <option value="cheese">Cheese</option>
    <option value="tuna">Tuna</option>
    <option value="pineapple">Pineapple</option>
</Field>

在子组件中:

const eatOptions = [
    {key: 'c', text: 'Chicken', value: 'chicken'},
    {key: 'h', text: 'Ham', value: 'ham'},
    {key: 'm', text: 'Mushrooms', value: 'mushrooms'},
    {key: 't', text: 'Tuna', value: 'tuna'}
];

// And in the Form:
<Field name="toppingsB" component="select" options={eatOptions}>
    { ({input,  meta, options}) => {
        return (
            <Opts options={options} name={input.name}/>
        )
    }}
</Field>

结果是HTML看起来一样(我猜的不多),ToppingsA在值中(在onSubmit上)和ToppingsB中没有。我无法弄清楚我在这里失踪了什么,非常感谢你的帮助。

先谢谢,伯特

reactjs semantic-ui-react react-final-form
2个回答
2
投票

如果你使用toppingsB的render-props,那么Field export const Opts = (props) => { return ( <select name={props.name}> {props.options.map((x) => { return ( <option key={x.key} value={x.value}>{x.text}</option> ) })} </select> ) }; prop不应该是“select”类型,因为Field的子项将是一个函数而不是多个标记。

看起来您还没有让您的表单知道子组件内发生的任何更改。尝试传递component组件和onChange函数作为prop:

Opts

1
投票

@ S.Taylor,谢谢你的帮助!!有用。

作为参考工作代码:

父组件中的字段:

 <Opts 
    options={options}
    name={input.name}
    onChange={ (value:string) => input.onChange(value)}
  />

和子组件中的代码:

<Field name="toppingsB" options={eatOptions} >
    { ({input,  meta, options}) => {
        return (
            <Opts
                options={options}
                name={input.name}
                onChange={ (value) => input.onChange(value)}
            />
        )
    }}
</Field>
© www.soinside.com 2019 - 2024. All rights reserved.