[英]react component connected, redux state changes… but no update to component?
我正在為多渠道聊天應用程序創建 React/Redux 前端。 我在使用redux
、 react-redux
和redux-thunk
在狀態更改后重新渲染一些 React 組件時遇到問題。
我相信我的減速器是非變異的,並且我是通過react-redux
的connect
訂閱的。 當我運行應用程序並查看瀏覽器控制台時,我看到組件的初始渲染(即初始狀態為空),然后狀態發生變化(由index.js
的動作調度觸發)......然后我會期望組件使用新的道具重新渲染,但它不會發生。
我在這里放了一個倉庫: https : //github.com/mattmoss/react-redux-no-update
node_modules
不在 repo 中,所以要運行,首先下載依賴項(運行yarn
就足夠了),然后npm start
。
一些摘錄(請參閱 repo 中的完整源代碼):
reducers/channelList.js
import * as c from '../actions/constants';
export default function channelList(state = [], action) {
switch (action.type) {
case c.FETCH_CHANNELS_SUCCESS:
return action.channels;
default:
return state;
}
}
actions/channelActions.js
export function fetchChannels() {
return (dispatch) => {
return ChannelApi.allChannels()
.then(channels => dispatch(fetchChannelsSuccess(channels)))
.catch(error => { throw(error); });
};
}
export function fetchChannelsSuccess(channels) {
return {
type: c.FETCH_CHANNELS_SUCCESS,
channels
};
}
components/ChannelListView.js
class ChannelListView extends React.Component {
render() {
const { channels, current, onSelect } = this.props;
console.log("channels:", channels, "current:", current);
return (
<ListGroup>
{channels.map(channel =>
<ListGroupItem
key={channel.id}
active={channel.id === this.props.current}
onClick={onSelect(channel.id)}
>
<strong>#{channel.name}</strong>
</ListGroupItem>
)}
</ListGroup>
);
}
}
export default ChannelListView;
containers/ChannelList.js
import ChannelListView from '../components/ChannelListView';
const mapStateToProps = (state, ownProps) => {
return {
channels: state.channelList,
current: state.currentChannel
};
};
const mapDispatchToProps = (dispatch) => {
return {
onSelect: (id) => () => {}
};
};
export default connect(mapStateToProps, mapDispatchToProps)(ChannelListView);
App.js
class App extends Component {
render() {
return (
<Grid>
<Row>
<Col>
<h1>Channels</h1>
<ChannelList />
</Col>
</Row>
</Grid>
);
}
}
index.js
const store = configureStore();
store.dispatch(fetchChannels());
ReactDOM.render(
<Provider store={configureStore()}>
<App />
</Provider>,
document.getElementById('root')
);
store/configureStore.js
import { createStore, applyMiddleware } from 'redux';
import rootReducer from '../reducers/rootReducer';
import thunk from 'redux-thunk';
import logger from 'redux-logger';
export default function configureStore() {
return createStore(
rootReducer,
applyMiddleware(thunk, logger)
);
}
我不是 100%,因為我自己對 React 還是比較陌生。 但是看看你的index.js
腳本。
// You configure the store, then dispatch the fetchChannels action
const store = configureStore();
store.dispatch(fetchChannels());
ReactDOM.render(
// But here, you're recreating the store again, which I think will re-initialise an empty store
// Change this to use the `store` variable from above.
<Provider store={configureStore()}>
<App />
</Provider>,
document.getElementById('root')
);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.