- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 redux 状态是这样的:
{
parks: [
{
_id:"ad1esdad",
fullName : "Some Name"
},
{
_id:"ad1es3s",
fullName : "Some Name2"
}
],
parkInfo: {
id : "search Id",
start_time : "Some Time",
end_time : "Some Time"
}
}
我有一个parkSelector
用户从中选择parkId、start_time和end_time的组件
import React, { Component } from 'react';
import { changeParkInfo } from '../../Actions';
class ParkSelector extends Component {
constructor(props) {
super(props);
this.handleApply = this.handleApply.bind(this);
this.rederOptions = this.rederOptions.bind(this);
this.state = {
startDate: moment().subtract(1, 'days'),
endDate: moment(),
parkId : this.props.parks[0]
};
}
handleApply(event) {
this.setState({
parkId : event.target.parkId.value
startDate: event.target.start_time.value,
endDate: event.target.end_time.value,
});
this.props.changeParkInfo(this.state.parkId,this.state.startDate,this.state.endDate);
}
rederOptions(){
return _.map(this.props.parks,(park,index)=>{
return(
<option value={park._id} key={park._id}>{park.profile.fullName}</option>
);
});
}
render() {
return (
<div className="row">
<div className="pb-4 col-sm-3">
<form onSubmit={this.handleApply}>
<select name="parkId" value={this.state.parkId} className="form-control input-sm">
{this.rederOptions()}
</select>
<input name="start_time" type="date" />
<input name="end_time" type="date" />
<button type="submit">Apply</button>
</form>
</div>
</div>
)
}
}
function mapStateToProps(state){
return {
parks : state.parks
};
}
export default connect(mapStateToProps,{ changeParkInfo })(ParkSelector);
我有另一个组件“stats”,它需要显示与 parkInfo
相关的信息这将加载我的 api 请求。
import React, { Component } from 'react';
import StatsCard from '../../components/StatsCard';
import { getDashboardStats } from '../../Actions';
class Dashboard extends Component {
constructor(props) {
super(props);
}
render() {
return (
<div className="animated fadeIn">
<div className="row">
<StatsCard text="Revenue Collected" value={9999} cardStyle="card-success" />
<StatsCard text="Total Checkins" value={39} cardStyle="card-info" />
<StatsCard text="Total Checkouts" value={29} cardStyle="card-danger" />
<StatsCard text="Passes Issued" value={119} cardStyle="card-warning" />
</div>
</div>
)
}
}
function mapStateToProps(state){
return {
parkInfo : state.parkInfo,
dashboardStats : state.dashboardStats
};
}
export default connect(mapStateToProps,{ getDashboardStats })(Dashboard);
我需要调用getDashboardStats
每当 dashboardStats
的 redux 状态发生时,都会执行操作(进行 api 调用并将结果存储在 redux 状态的 parkInfo
中)变化。
调用此操作的最佳方式是什么,我已经尝试过 componentWillUpdate
但它继续无限更新。这种情况的最佳实践是什么?
最佳答案
我遇到了类似的问题,但找到了合适的方法。我认为这个问题与 Redux 应用程序中 reducer 和订阅者的职责通常如何解释有关。我的项目没有使用 React,它只是 Redux,但潜在的问题是相同的。为了强调回答根本问题,我从一般 Angular 来处理这个主题,而不直接引用您的 React 特定代码。
问题回顾:在应用中,多个操作 P、Q、R 可能会导致状态更改 C。您希望此状态更改 C 触发异步操作 X,而不管操作最初导致状态变化 C。换句话说,异步操作 X 与状态变化耦合,但有意与可能导致变化 C 的各种操作 (P,Q,R) 解耦。这种情况不会发生在简单的 hello-todo 示例,但确实发生在现实世界的应用程序中。
天真的答案1:你不能触发另一个 Action ,它会导致无限循环。
天真的答案2:你不能触发另一个 Action ,reducer不能触发 Action 或引起任何副作用。
虽然这两个天真的答案都是正确的,但他们的基本假设是错误的。第一个错误地假设 Action X 是同步触发的并且没有任何停止条件。第二个错误地假设操作 X 是在 reducer 中触发的。
答案:
在订阅者(也称为渲染器)中以异步方式触发操作 X。乍一听起来可能很奇怪,但事实并非如此。即使是最简单的 Redux 应用程序也能做到这一点。他们监听状态变化并根据变化采取行动。让我解释一下。
订阅者除了呈现 HTML 元素之外,还定义如何触发操作来响应用户行为。除了处理用户行为之外,他们还可以定义如何触发操作以响应世界上的任何其他变化。用户在五秒后单击按钮与 setTimeout 在五秒后触发操作之间几乎没有区别。除了让订阅者将操作绑定(bind)到点击事件或者找到 GPS 位置之外,我们还可以让他们将操作绑定(bind)到超时事件。初始化后,允许在每次状态更改时修改这些绑定(bind),就像我们在状态更改时重新渲染按钮或整个页面一样。
由 setTimeout 触发的操作将导致类似循环的结构。超时触发操作,reducer 更新状态,redux 调用订阅者,订阅者设置新的超时,超时触发操作等。但同样,与正常渲染和事件与用户行为绑定(bind)所导致的循环结构没有什么区别。它们都是异步的和预期的循环过程,允许应用程序与世界通信并按照我们喜欢的方式运行。
因此,检测订阅者感兴趣的状态变化,并在变化发生时自由地触发操作。推荐使用 setTimeout,即使延迟为零,只是为了让您清楚事件循环的执行顺序。
忙循环当然是一个问题,必须避免。如果 Action X 本身导致这样的状态变化,将立即再次触发它,那么我们就会遇到一个繁忙的循环,应用程序将停止响应或变得缓慢。因此,请确保触发的操作不会导致此类状态更改。
如果您想实现重复刷新机制,例如每秒更新一个计时器,可以用相同的方式完成。然而,这种简单的重复不需要监听状态变化。因此,在这些情况下,最好使用 redux-thunk 或编写异步操作创建器。这样代码的意图就变得更容易理解。
关于javascript - React-redux : listening to state changes to trigger action,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47687026/
编辑:为了澄清,我想问的是:在什么情况下您会更喜欢一种语法而不是另一种语法? 有什么区别: .trigger('change') 和 .change() 两者都按预期工作。在任何情况下语法都会有所不同
这个问题在这里已经有了答案: Difference between .on('click') vs .click() (12 个答案) 关闭 6 年前。 有什么区别: $('选择器').change
我用的是Select2-4.0.0 和 $gameSelect.select2().on("change",function(e){....} 工作正常。 但是当我将它链接起来时('change')就
有一天在#haskell 上,有人提到了当字符串改变时字符串的类型应该如何改变的概念。这让我想起了我项目中的一些代码。它一直困扰着我,我说不清为什么。我现在推测,原因是我没有实现这个概念。这是下面的代
我使用了 .on("change") 事件函数,因为我的整个代码中有一部分是动态变化的。 .trigger("change") 在 .change() 中工作正常,但在 .on("change") 中
下面是一个非常简单的表单下拉列表设置。但是,on-change 事件拒绝触发...除非它更改为 ng-change。 这让我卡住了大约一个小时,因为我们在网站的其他地方使用了相同的设置(即模型属性/列
我有两个v-model 案例一: 这很好用 案例二: 即使改变 u1 也会触发 onDateChange(); 最佳答案 :change 绑定(bind)属性,如 v-bind:change=
我找到了 .and方法对于链接许多期望非常有用。 expect { click_button 'Update Boilerplate' @boilerplate_original.reload
出于合规性原因,我需要捕获所有数据库更改。我知道 Change Feed 存储此信息(并且我正在等待完全保真度来捕获删除)。目前,我一直在通过 Function 触发器读取 Change Feed 并
我添加了一个data-ng-change='getSubjectsClasswise(classBean.class_id);'上课标签,但主题未在主题 处加载标签。 一切看起来都很好,没有遇到问题
我有一组复选框,当您单击其中一个时,它们应该全部被选中。 当用户单击一个复选框时,它会检查以该类名称开头的所有其他复选框。我想要的是用户单击一个复选框,并且每次单击仅触发一次 $(".atpSelec
我在 Stack Overflow 上阅读了很多有关此问题的内容,并应用了所有建议的解决方案(getShell pack、布局、getparent 布局等...),但没有一个起作用。 我有一个带有文本
我想更改我的索引。我的数据框如下: partA = pd.DataFrame({'u1': 2, 'u2': 3, 'u3':4, 'u4':29, 'u5':4, 'u6':1, 'u7':323,
我有一个像这样的下拉菜单: Grade Year 旁边还有另一个下拉菜单: 3 4
这个问题已经有人问过,但我只停留在最基本的层面上。除了选择标记和尝试通过 jquery 捕获更改事件外,我没有向我的 html 添加任何内容。这是我的代码: $('#target').bin
我只是 Django 的新手几天。现在,当自定义表单中其他字段的值发生变化时,我需要同时更改一个字段中的值和表示形式。此时更改 MyModel 是受限。 我的应用程序/models.py: class
我正在使用 ListView 控件来显示一些数据行。有一个后台任务接收列表内容的外部更新。新收到的数据可能包含更少、更多或相同数量的项目,而且项目本身可能已更改。 ListView.ItemsSour
我在 android studio 中使用 git 插件。我的问题是当我提交更改列表(公开提交)时,但我在更改列表中的评论是错误的/丢失的,我想更改它。 问题: 有没有办法通过 AndroidStud
MyCustomObject * object=new MyCustomObject(); 假设我的许多类都使用了对象指针,但突然间我想在不更改地址的情况下更改指针的内容。 我认为 object =
我正在使用新的 KeyValue Observing。当变量发生变化时,我接到了我的观察者的电话,但 change struct 附带 newValue和 oldValue都为 nil ,所以它永远不
我是一名优秀的程序员,十分优秀!