フォームを多用するアプリがあるので、できる限り少ない依存関係を使用しながら、できるだけ多くの制御を行いたいと思います。そのために、redux-form v6のカスタムフィールドコンポーネントAPIを活用し、自由にドロップできるカスタムコンポーネントを大量に作成したいと思います。これらのコンポーネントの1つは、ドロップダウン選択です。
問題は、カスタムドロップダウンコンポーネントがOKになっても状態に接続しないことです。
ドキュメントでは、例は次のようにこれを達成します:
<Field name="favoriteColor" component="select">
<option></option>
<option value="#ff0000">Red</option>
<option value="#00ff00">Green</option>
<option value="#0000ff">Blue</option>
</Field>
私はコンポーネントをドロップし、プロップにデータの配列をフィードできるプラグアンドプレイのアプローチを探しています:
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>
これは今のところ機能しますが、これを完全に別個のコンポーネントとして実装できれば理想的ですが(最初の質問で説明したように)、フィールドが他のフィールドに依存する場合にライフサイクルフックを利用できます。
ドロップダウン選択を処理する個別のカスタムコンポーネントを作成するには、フォーム入力に接続するための「入力」プロップを含める必要がありました。
カスタムコンポーネント:
/**
*
* 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>