- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
--简短版本我的索引页面是所有锦标赛的列表。每个都有一个按钮,单击即可转到该锦标赛的页面。在每个锦标赛的索引中,我都有一个按钮,其中包含 onClick={}
在 Redux 中选择锦标赛数据的操作。
如何在下一页上正确访问该状态数据?
--长版我有一个锦标赛模型,在后端编写了一堆用于完整 CRUD 的快速路线。
我还写了redux..我得到了索引页面(数据库中所有锦标赛的列表)我将展示我的 GET ALL TOURRNAMENTS
代码,以便您可以了解我如何过渡到创建 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));
});
reducer
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" }));
});
reducer
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)));
};
我是否只需要为此创建一个新的 reducer ?我可以看到该州显示的锦标赛。在前端,我尝试从 State 中提取该数据,以便我可以使用 PropTypes 渲染数据。
我不想让这篇文章变得很长,但我会把我的显示文件放在这里,这样一切都会公开
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);
谢谢大家
最佳答案
如果您有该州的锦标赛
数据,您可以直接使用以下方法获取该数据 this.props
,并使用 TournamentShow
类中的 componentDidUpdate
函数。您可以验证该值是否已更新,在下一个示例中,我将使用 equals 库来比较锦标赛属性的值:
componentDidUpdate(prevProps) {
if(!equal(this.props.tournament, prevProps.tournament)) {
//Some operations with tournament value
}
}
关于javascript - MERN 和 Redux : How do you pass Redux state data from Index to Show page?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61433166/
我正在编写一个简单的有限状态机,并意识到在某些情况下,事件可以将状态变为多个可能的结果。基本上,从状态 A,如果事件 E 发生,状态可能是 C 或 D。 我目前正在使用此处编写的 Javascript
我在 React 中构建了一个应用程序,我在其中一个样板项目中找到了一行。 (state = {}) => state 谁能给我解释一下上面这行是什么意思?它是 javascript ES6 标准。
如何将多个状态变量组合成另一个? 我想通过一些用户交互来更改高度或宽度的值,并相应地更新 View 中的所有内容。所以高度或宽度会改变,面积也会改变。 我想它看起来像这样 @State var wid
我的容器正在通过 redux store 获取状态。 我通过这样的 Prop 将这个状态传递给模态框:示例: render(){ let {team,id} =this.props.data;
您好,我正在尝试使用 map 根据我所在状态的数组渲染选项,但在返回中使用它时我得到未定义 这是数组 this.state = { countries: ["Australia","Brazil"
我想将 this.state.currentPlayer 分配给 this.state.whosPlaying。它抛出错误TypeError:无法读取新板上未定义的属性“currentPlayer”。
我正在实现某种动态工作流程,当达到某个点时,我必须重新加载状态以呈现 HTML 并重新实例化 Controller 才能继续。 我发现我第二次调用 $state.reload() 不起作用。这是期望的
我正在开发一个 flutter 应用程序,并发现状态管理出现意外行为。我创建了一个示例应用来重现该行为,您可以在下面找到代码和日志输出。 该应用程序包含一个简单的 ListView,其中包含 10 个
有人可以举一个简单的例子,其中 state monad 比直接传递 state 更好吗? bar1 (Foo x) = Foo (x + 1) 对比 bar2 :: State Foo Foo bar
我想写类似 $state.go("/spheres/{{$stateParams.sphereId}}/mono/view"); 的内容使用外部 url 而不是状态,但这不起作用:( 现在我明白为什么
我正在使用“angular-ui-tree”:“^2.22.5” 点击执行某事菜单项时出错.. TypeError: this.$state is undefined 如何将对 $state 的引用传
我在elasticsearch中有文本字段,我想在kibana上可视化词云... 第一步,我们需要标记它们,我使用了“标准标记器” ... 使用这种形式的词云可视化结果如下图所示: 但是我需要的是专有
我正在尝试以编程方式在状态之间移动(使用 ui.router),而用户无需单击任何内容。文档位于 http://angular-ui.github.io/ui-router/site/#/api/ui
我想编写像“(event, state) -> state”这样的折叠函数。如果Java中没有任何模式匹配且不可变,我该如何编写它? 最佳答案 我认为您正在寻找 Java 中的函数式编程。 此版本中引
这个问题已经有答案了: What does an exclamation mark before a variable mean in JavaScript (4 个回答) 已关闭 8 年前。 您好,
https://plnkr.co/edit/bOZW1a9u62W1QA6cYjYj?p=preview 预期 登录后,所有 $states 都会初始化,然后单击 Ticker 按钮后,唯一应重新初始
试图决定(针对我的应用程序)在 onPause() 中保存什么以及要保存在 onSaveInstanceState() 中的内容,我梳理了整个 SO 以获得提示和明确的指导方针。 如果我没理解错的话,
在 Javascript 中,当我单击滚动条(页面中出现的任何滚动条)并将鼠标悬停在图像上时,图像再次开始拖动。 图像只能在鼠标按钮按下状态下拖动。 所以我试图通过了解鼠标按钮状态(mousedown
我见过 Maybe和 Either在代码中使用仿函数(和应用)是有道理的,但我很难想出一个 State 的例子。仿函数和应用。也许它们不是很有用,只是因为 State 才存在。 monad 需要一个仿
我非常努力地想围绕 State Monad,但我不明白以下内容: 鉴于 return 的实现和 (>>=) ,当你说 State $ \s ->.... ,在哪里s来自?我的意思是,当你开始表演时 >
我是一名优秀的程序员,十分优秀!