Your_Uncle_Ostap
@Your_Uncle_Ostap
Учусь премудростям

Нe получаю данные из Redux Store?

Всем привет. Пишу СПА.
Компонент который связан с Редаксом отдает данные через диспатч, но не получает их.
сам компонент:
lass BookList extends Component {
    componentDidMount() {
        // 1. receive data
        const {bookstoreService} = this.props;
        const data = bookstoreService.getBooks();
        //console.log(data); // full

        // 2. dispatch action to store
        this.props.booksLoaded(data);

    }

    render() {
        const {books} = this.props;
        return (
            <ul>
                {books.map(
                    (book) => {
                    return (<li key={book.id}><BookListItem book={book}/></li>)
                    })
                }
            </ul>
        )
    }


}

const mapStateToProps = ({books}) => {
    // console.log(books); // empty
    return {books}
};
const mapDispatchToProps ={
   booksLoaded
};


export default withBookstoreService()(connect(mapStateToProps, mapDispatchToProps)(BookList));


Редьюсер:
const initialState = {
    books: []
};

const reducer = (state = initialState, action) => {
//console.log(action.payload); //full
    switch (action.type) {
        case 'BOOK_LOADED':
            return {
                books: action.payload
            };


        default:
            return state;
    }

};
export default reducer;


Экшн:
const booksLoaded = (newBooks) => {
  
    // console.log(newBooks);  //full
    return {
        type: 'BOOKS_LOADED',
        payload: newBooks
    }
};
export {booksLoaded};
  • Вопрос задан
  • 120 просмотров
Решения вопроса 1
@Che603000
c 2011 javascript
Актион без диспатч вызван

Class BookList extends Component {
    componentDidMount() {
        // 1. receive data
        const {bookstoreService} = this.props;
        const data = bookstoreService.getBooks();
        //console.log(data); // full

        // 2. dispatch action to store
       this.props.dispatch( this.props.booksLoaded(data)); // !!!! dispatch
    }
    ....
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект
22 нояб. 2024, в 23:55
3000 руб./за проект