【发布时间】:2016-10-16 20:47:27
【问题描述】:
我有一个应用程序会很重,我想要尽可能多的控制,同时使用尽可能少的依赖项。为此,我想利用 redux-form v6 的自定义 Field 组件 API 并制作一堆我可以随意放入的自定义组件。其中一个组件是下拉选择。
问题是自定义下拉组件没有连接到状态,即使它呈现正常。
在文档中,示例完成如下:
<Field name="favoriteColor" component="select">
<option></option>
<option value="#ff0000">Red</option>
<option value="#00ff00">Green</option>
<option value="#0000ff">Blue</option>
</Field>
我正在寻找一种即插即用的方法,我可以在其中放入一个组件,并将一组数据输入到 props 中:
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 时,与下拉列表交互时,该字段的值永远不会填充:
我为这两个字段选择了一个值,但只有“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>
这目前有效,但如果我可以将其实现为一个完全独立的组件(如初始问题中所述),那将是理想的,因此我可以在该字段依赖于其他字段的情况下利用生命周期挂钩.
【问题讨论】:
标签: javascript reactjs html-select redux-form