gpt4 book ai didi

javascript - 如何使用 Redux-Form V6 创建自定义下拉字段组件?

转载 作者:可可西里 更新时间:2023-11-01 02:36:50 24 4
gpt4 key购买 nike

我有一个应用程序会很繁重,我希望尽可能多地控制,同时尽可能少地使用依赖项。为此,我想利用 redux-form v6 的自定义 Field 组件 API 并制作一堆我可以随意放入的自定义组件。这些组件之一是下拉选择。

问题是自定义下拉组件没有连接到状态,即使它呈现 OK。

在文档中,示例完成这样的操作:

<Field name="favoriteColor" component="select">
<option></option>
<option value="#ff0000">Red</option>
<option value="#00ff00">Green</option>
<option value="#0000ff">Blue</option>
</Field>

我正在寻找一种即插即用的方法,我可以在其中放入一个组件,并将一组数据输入到 Prop 中:

Form.js:

      <div className="form-group">
<label htmlFor="dropDownSelect">Select an Option</label>
<Field
name="dropDownSelect"
component={DropDownSelect}
people={people}
className="form-control"
>
</Field>
</div>

DropDownSelect.js:

import React from 'react';

import styles from './styles.css';

class DropDownSelect extends React.Component { // eslint-disable-line react/prefer-stateless-function
renderSelectOptions = (person) => {
return (
<option key={person} value={person}>{person}</option>
);
}

render() {
return (
<select>
{this.props.people.map(this.renderSelectOptions)}
</select>
);
}
}


export default DropDownSelect;

当我检查 Redux DevTools 时,与下拉列表交互时该字段的值从不填充:

enter image description here

我为两个字段都选择了一个值,但只有“effDate”填充了一个值,而“dropDownSelect”仍然是一个没有值的注册字段。

编辑:

根据这个例子,我想解决这个问题的方法是这样的:

function DropDownSelect(person) {
return (
<option key={person} value={person}>{person}</option>
);
}

export default DropDownSelect;


<div className="form-group">
<label htmlFor="dropDownSelect">Select an Option</label>
<Field
name="dropDownSelect"
component="select"
// component={DropDownSelect}
// people={people}
className="form-control"
>
{people.map(DropDownSelect)}
</Field>

这目前有效,但如果我可以将其实现为一个完全独立的组件(如初始问题中所述),那将是理想的,这样我就可以在该字段依赖于其他字段的情况下利用生命周期 Hook .

最佳答案

为了制作单独的自定义组件来处理下拉选择,我需要包含“输入” Prop 以将其连接到表单缩减器:

自定义组件:

/**
*
* DropDownSelect
*
*/

import React from 'react';

import styles from './styles.css';

class DropDownSelect extends React.Component { // eslint-disable-line react/prefer-stateless-function

renderSelectOptions = (person) => (
<option key={person} value={person}>{person}</option>
)

render() {
const { input, label } = this.props;
return (
<div>
{/* <label htmlFor={label}>{label}</label> */}
<select {...input}>
<option value="">Select</option>
{this.props.people.map(this.renderSelectOptions)}
</select>
</div>
);
}
}

// function DropDownSelect(person) {
// return (
// <option key={person} value={person}>{person}</option>
// );
// }

DropDownSelect.propTypes = {
people: React.PropTypes.array,
input: React.PropTypes.object,
label: React.PropTypes.string,
};

export default DropDownSelect;

领域:

      <div className="form-group">
<label htmlFor="dropDownSelect">Select an Option</label>
<Field
name="dropDownSelect"
// component="select"
label="dropDownSelect"
component={DropDownSelect}
people={people}
className="form-control"
>
{/* {people.map(DropDownSelect)} */}
</Field>
</div>

关于javascript - 如何使用 Redux-Form V6 创建自定义下拉字段组件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40075281/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com