Ciao uso la mappa immutabile per stato e quando provo maspStateToProps ho questo errore.mapStateToProps deve restituire un oggetto. Invece ha ricevuto la mappa {}?
Violazione invariante non rilevata:
mapStateToProps
deve restituire un oggetto. Mappa invece ricevuta {}.
Ecco il mio codice:
Componente:
const mapStateToProps = (state) => {
return state
}
class LoanCalculator extends React.Component{
componentWillMount(){
this.dispatch(loadConstraints());
}
render(){
return (
<div>
<h1> Loan Calculator </h1>
<SlidersBox {...this.props}/>
</div>
)
}
}
LoanCalculator = connect(
mapStateToProps
)(LoanCalculator)
export default LoanCalculator
RIDUTTORE
import { Map } from 'immutable'
import {LOAD_CONSTRAINTS, SET_AMOUNT_VALUE, SET_TERM_VALUE} from "../actions/actions";
const initialState = new Map();
export default function calculator(state = initialState, action){
switch (action.type){
case LOAD_CONSTRAINTS:
return state.set("constraints", action.constraints)
case SET_AMOUNT_VALUE:
return state.set("selectedAmount", action.amount)
case SET_TERM_VALUE:
return state.set("selectedTerm", action.term)
default:
return state
}
}
tuo stato sembra essere una mappa da immutable.js, mentre mapStateToProps deve restituire un oggetto, come il vostro errore messaggio dice Prova a restituire un oggetto convertendo la mappa o estraendo i valori necessari in una struttura di oggetti. – Robin
Perché non solo "return {state}'? – lux