redux-formを使用して初期フォームのフィールド値を設定する際にいくつか問題があります。Reduxフォーム - 初期値が状態で更新されない
私はredux-form v6.0.0-rc.3を使用しており、v15.3.0に反応しています。
これは私の問題です。ユーザーのグリッドがあり、ユーザーの行をクリックすると、ユーザーの編集ページに移動し、ユーザーIDをURLに含めます。その後、ユーザーの編集ページで、idを取得してthis.pate.usersを返すアクション作成者であるfetchUser(this.props.params.id)を呼び出しています。
がfunction mapStateToProps(state) {
return { initialValues: state.users.user }
}
私の理解では、これがinitialValuesがstate.users.userに設定する必要があり、この状態が更新されるたびinitialValuesも更新する必要があります。私はその後呼び出すことで、フォームinital値を設定しようとしています。これは私には当てはまりません。 InitialValuesは、以前にクリックされたユーザ行(すなわち、this.state.users.userの以前の状態)に設定されています。だから私はこれをテストして、このコンポーネントにボタンを追加することを決定し、そのクリックされたとき、私はハードにコーディングされたユーザーIDで再びfetchUserを呼び出しています:
this.props.fetchUser('75e585aa-480b-496a-b852-82a541aa0ca3');
これは正しく状態を更新けどinitialValuesの値れます変えないで。状態が更新されると更新されません。私はこの同じプロセスをredux形式の古いバージョンでテストし、期待どおりに動作しました。
私はここで何か間違っているか、これは私が使用しているバージョンの問題です。
ユーザー編集フォーム -
class UsersShowForm extends Component {
componentWillMount() {
this.props.fetchUser(this.props.params.id);
}
onSubmit(props){
console.log('submitting');
}
changeUser() {
this.props.fetchUser('75e585aa-480b-496a-b852-82a541aa0ca3');
}
renderTextField(field) {
return (
<TextField
floatingLabelText={field.input.label}
errorText={field.touched && field.error}
fullWidth={true}
{...field.input}
/>)
}
render() {
const { handleSubmit, submitting, pristine } = this.props;
return(
<div>
<form onSubmit={handleSubmit(this.onSubmit.bind(this))} className="mdl-cell mdl-cell--12-col">
<Field name="emailAddress" component={this.renderTextField} label="Email Address"/>
<Field name="firstName" component={this.renderTextField} label="First Name"/>
<Field name="lastName" component={this.renderTextField} label="Last Name"/>
</form>
<RaisedButton onClick={this.changeUser.bind(this)} label="Primary" primary={true} />
</div>
);
}
}
function mapStateToProps(state) {
return { initialValues: state.users.user }
}
UsersShowForm = reduxForm({
form: 'UsersShowForm'
})(UsersShowForm)
UsersShowForm = connect(
mapStateToProps,
actions
)(UsersShowForm)
export default UsersShowForm
ユーザーリデューサー -
import {
FETCH_USERS,
FETCH_USER
} from '../actions/types';
const INITIAL_STATE = { all: [], user: {} };
export default function(state = { INITIAL_STATE }, action) {
switch (action.type) {
case FETCH_USERS:
return {...state, all: action.payload };
case FETCH_USER:
return {...state, user: action.payload };
default:
return state;
}
}
リデューサーインデックス -
import { combineReducers } from 'redux';
import { reducer as formReducer } from 'redux-form';
import usersReducer from './users_reducer';
const rootReducer = combineReducers({
form: formReducer,
users: usersReducer
});
export default rootReducer;
あなたのユーザー減速でより多くの情報と完全な例を探すので名前がありません。 NPMでビルドするときにエラーが発生しますか? – Martin
あなたは何を意味するのか分かりません。私は、あなたのユーザーのレデューサーをエクスポートして、それをindex - import usersReducerから './users_reducer'にインポートしています。エラーは発生せず、他のすべてのシナリオでUser reducerが正常に動作します。 –
私が意味するのは、あなたがあなたの関数に名前をつけてはいけない、 'export default function()'を使うときです。 インデックスリデューサが使用するために、「default関数usersReducer()をエクスポートする」と表示されます。 – Martin