我试图在我的组件上显示一些虚拟数据,但我没有看到任何显示在它上面。当我console.log
得到预期的结果时[object Object]
。
我想我的actions
,actionCreators
和reducers
.
#actions/types.js
export const FETCH_USERS = 'fetch_users';
#actions/index.js
import {
FETCH_USERS
} from './types';
const user = [
{ name: 'D/S' },
{ name: 'Bob' },
{ name: 'Juan' }
]
export function fetchUsers() {
return { type: FETCH_USERS, payload: user }
}
#reducers/users_reducer.js
import {
FETCH_USERS
} from '../actions/types';
export default function (state = [], action) {
switch(action.type) {
case FETCH_USERS:
return [ ...state, ...action.payload ];
}
return state;
}
#reducers/index.js
import { combineReducers } from 'redux';
import UsersReducer from './users_reducer';
const rootReducer = combineReducers({
users: UsersReducer
});
export default rootReducer;
# components/UserList.js
import React, { Component } from 'react';
import { connect } from 'react-redux';
import styles from './App.css';
import * as actions from '../actions';
class UserList extends Component {
componentWillMount() {
const fetchedUsers = this.props.fetchUsers() ? this.props.fetchUsers() : 'No users at this time';
console.log(`This is the list of users: ${fetchedUsers}`); // <= here I just get [object Object]
}
renderUser(user) {
<div className={ styles.card }>
<h4>{ user.name }</h4>
<p>Lego Inc</p>
<a>Email</a>
</div>
}
render() {
const userList = this.props.users.map(this.renderUser);
console.log(`${userList}`);
return (
<div>
{ userList }
</div>
)
}
}
function mapStateToProps(state) {
return { users: state.users }
}
export default connect(mapStateToProps, actions)(UserList);
# components/App.js
import React from 'react';
import styles from './App.css';
import UserList from './UserList';
const App = () => (
<div className={''}>
<h2>React Redux middleware</h2>
<div>
<UserList />
</div>
</div>
);
export default App;