MERN 和 Redux:如何将 Redux 状态数据从 Index 传递到 Show 页面?
MERN & Redux: How do you pass Redux state data from Index to Show page?
--简短版本
我的索引页面是所有锦标赛的列表。每个都有一个按钮,您可以单击该按钮转到该锦标赛的页面。
在每个锦标赛的索引中,我都有一个按钮,该按钮具有 onClick={}
在 Redux 中选择该锦标赛数据的操作。
如何在下一页正确访问该状态数据?
--长版
我有一个锦标赛模型,在后端为完整的 CRUD 编写了一堆快速路线。
我也写了redux..我得到了索引页面(数据库中所有锦标赛的列表)
我将展示我的 GET ALL TOURNAMENTS
代码,这样您就可以看到我是如何过渡到创建 SHOW ONE TOURNAMENT
代码的。
后端 ExpressJS 路由
// @route GET /tournaments
// @descrip Get All, INDEX
// @access Public
router.get('/', (req, res) => {
Tournament.find()
.sort({ date: -1 })
.then(tournaments => res.json(tournaments))
.catch(err => console.log(err));
});
减速机
const initialState = {
tournaments: [],
loading: false
}
case GET_TOURNAMENTS:
return {
...state,
tournaments: action.payload,
loading: false
};
动作
export const getTournaments = () => dispatch => {
dispatch(setTourneysLoading());
axios
.get('/tournaments')
.then(res => dispatch({
type: GET_TOURNAMENTS,
payload: res.data
}))
.catch(err => dispatch(returnErrors(err.response.data, err.response.status)));
};
好的..感谢您的耐心等待!这是我为 SHOW
准备的
快线
// @route SHOW /tournaments/:id
// @descrip Display a single tournament
// @access Public
router.get('/:id', (req, res) => {
Tournament.findById(req.params.id)
.then(tournament => res.json(tournament))
.catch(err => res.status(404).json({ msg: "Tournament not found" }));
});
减速器
case DISPLAY_TOURNAMENT:
return {
...state,
// Iterate through tournaments to find one that matches payload
tournaments: state.tournaments.map(tournament => tournament._id === action.payload ?
// display that tournament
{ tournament } :
// else, display nothing
null
),
loading: false
};
动作
export const showTournament = id => dispatch => {
dispatch(singleTourneyLoading());
axios
.get(`/tournaments/${id}`)
.then(() => dispatch({
type: DISPLAY_TOURNAMENT,
payload: id
}))
.catch(err => dispatch(returnErrors(err.response.data, err.response.status)));
};
我是否只需要为此单独创建一个新的减速器?
我可以在州内看到显示的锦标赛。在前端,我试图从 State 中提取它,以便我可以使用 PropTypes 呈现数据。
我不想把它弄得很大post但我会把我的表演文件放在这里所以一切都公开了
import React, { Component } from 'react';
import { Link } from 'react-router-dom';
import TournamentDescription from './descriptions';
import { showTournament } from '../../actions/tournamentActions';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
class TournamentShow extends Component {
componentDidMount() {
this.props.showTournament(this.props.tournament._id);
};
static propTypes = {
showTournament: PropTypes.func.isRequired,
tournament: PropTypes.object.isRequired,
auth: PropTypes.object.isRequired
};
render() {
const { _id, title, hostedBy, status, participants } = this.props.tournament;
return (
<div>
<h1>{ title }</h1>
<h3> <TournamentDescription key={_id} title={ title } /> </h3>
<p>status: { status }</p>
<p>Registered Fighters:
{
participants.map((participant, index) => {
return (
<ul key={ index }>
<li>{ participant }</li>
</ul>
)
})
}
</p>
<p>Hosted by: { hostedBy }</p>
<Link to="#">Sign Up</Link>
<Link to="/">Back to Tournaments main page</Link>
</div>
)
}
};
const mapStateToProps = state => ({
tournament: state.tournament.tournaments[0],
auth: state.auth
});
export default connect(mapStateToProps, { showTournament })(TournamentShow);
谢谢大家
如果你有状态中的tournament
数据,你可以直接使用
this.props
,并且还使用 TournamentShow
class 中的 componentDidUpdate
函数。您可以验证该值是否已更新,在下一个示例中,我将使用 equals 库来比较锦标赛 属性:
的值
componentDidUpdate(prevProps) {
if(!equal(this.props.tournament, prevProps.tournament)) {
//Some operations with tournament value
}
}
--简短版本
我的索引页面是所有锦标赛的列表。每个都有一个按钮,您可以单击该按钮转到该锦标赛的页面。
在每个锦标赛的索引中,我都有一个按钮,该按钮具有 onClick={}
在 Redux 中选择该锦标赛数据的操作。
如何在下一页正确访问该状态数据?
--长版 我有一个锦标赛模型,在后端为完整的 CRUD 编写了一堆快速路线。
我也写了redux..我得到了索引页面(数据库中所有锦标赛的列表)
我将展示我的 GET ALL TOURNAMENTS
代码,这样您就可以看到我是如何过渡到创建 SHOW ONE TOURNAMENT
代码的。
后端 ExpressJS 路由
// @route GET /tournaments
// @descrip Get All, INDEX
// @access Public
router.get('/', (req, res) => {
Tournament.find()
.sort({ date: -1 })
.then(tournaments => res.json(tournaments))
.catch(err => console.log(err));
});
减速机
const initialState = {
tournaments: [],
loading: false
}
case GET_TOURNAMENTS:
return {
...state,
tournaments: action.payload,
loading: false
};
动作
export const getTournaments = () => dispatch => {
dispatch(setTourneysLoading());
axios
.get('/tournaments')
.then(res => dispatch({
type: GET_TOURNAMENTS,
payload: res.data
}))
.catch(err => dispatch(returnErrors(err.response.data, err.response.status)));
};
好的..感谢您的耐心等待!这是我为 SHOW
准备的快线
// @route SHOW /tournaments/:id
// @descrip Display a single tournament
// @access Public
router.get('/:id', (req, res) => {
Tournament.findById(req.params.id)
.then(tournament => res.json(tournament))
.catch(err => res.status(404).json({ msg: "Tournament not found" }));
});
减速器
case DISPLAY_TOURNAMENT:
return {
...state,
// Iterate through tournaments to find one that matches payload
tournaments: state.tournaments.map(tournament => tournament._id === action.payload ?
// display that tournament
{ tournament } :
// else, display nothing
null
),
loading: false
};
动作
export const showTournament = id => dispatch => {
dispatch(singleTourneyLoading());
axios
.get(`/tournaments/${id}`)
.then(() => dispatch({
type: DISPLAY_TOURNAMENT,
payload: id
}))
.catch(err => dispatch(returnErrors(err.response.data, err.response.status)));
};
我是否只需要为此单独创建一个新的减速器? 我可以在州内看到显示的锦标赛。在前端,我试图从 State 中提取它,以便我可以使用 PropTypes 呈现数据。
我不想把它弄得很大post但我会把我的表演文件放在这里所以一切都公开了
import React, { Component } from 'react';
import { Link } from 'react-router-dom';
import TournamentDescription from './descriptions';
import { showTournament } from '../../actions/tournamentActions';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
class TournamentShow extends Component {
componentDidMount() {
this.props.showTournament(this.props.tournament._id);
};
static propTypes = {
showTournament: PropTypes.func.isRequired,
tournament: PropTypes.object.isRequired,
auth: PropTypes.object.isRequired
};
render() {
const { _id, title, hostedBy, status, participants } = this.props.tournament;
return (
<div>
<h1>{ title }</h1>
<h3> <TournamentDescription key={_id} title={ title } /> </h3>
<p>status: { status }</p>
<p>Registered Fighters:
{
participants.map((participant, index) => {
return (
<ul key={ index }>
<li>{ participant }</li>
</ul>
)
})
}
</p>
<p>Hosted by: { hostedBy }</p>
<Link to="#">Sign Up</Link>
<Link to="/">Back to Tournaments main page</Link>
</div>
)
}
};
const mapStateToProps = state => ({
tournament: state.tournament.tournaments[0],
auth: state.auth
});
export default connect(mapStateToProps, { showTournament })(TournamentShow);
谢谢大家
如果你有状态中的tournament
数据,你可以直接使用
this.props
,并且还使用 TournamentShow
class 中的 componentDidUpdate
函数。您可以验证该值是否已更新,在下一个示例中,我将使用 equals 库来比较锦标赛 属性:
componentDidUpdate(prevProps) {
if(!equal(this.props.tournament, prevProps.tournament)) {
//Some operations with tournament value
}
}