- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
假设我有三个 Web 组件 - A、B 和 C - 每个组件都关注全局 redux 存储。这三者都观察状态的变化,并在他们认为合适的时候使用react。
组件 A 触发一个 redux Action ,它改变状态中的一个值:{ showPopups: true }
组件 B 和 C 注意到这个值,并分别通过显示弹出窗口进行响应。现在,预期的行为已经执行,但 showPopups
仍然是 true
。
组件 A 触发第二个不相关的 redux 操作 - 结果,状态发生变化,组件 B 和 C 注意到 showPopups
值仍然是 true
,并响应第二次显示他们的弹出窗口。
我们不希望这样——避免这种情况的一种简单方法是在组件 B 和 C 中设置 lastShowPopups
,将最后一个值与当前值进行比较,仅 如果值更改从false
到true
,则触发弹出显示。
但是,如果组件 A 再次触发第一个 redux 操作怎么办? showPopups
已经是 true
,这意味着状态不会改变,这意味着弹出窗口不会显示。我们可以尝试通过巧妙地设置该值来避免这种情况 - 例如,我们可以将值分配为 new Boolean(1)
而不是 true
。 new Boolean(1)
是真的,但它并不严格等于另一个 new Boolean(1)
,对吧?
因此它仍然会触发状态更改,这意味着我们的组件注意到 showPopups
设置为 true
,并且...忽略它,因为它们的内部 lastShowPopups
变量也仍然是 true
。
我们如何告诉组件 B 和 C 只触发它们的行为一次,第一次,当不相关的状态变化发生并且触发行为的旧值保持不变时不要重新触发,但也允许这些行为重新触发如果促成状态值变化的 Action 再次发生?
换句话说,您可以使用 Redux 状态更改来触发不同 Web 组件中的一次性行为吗?
最佳答案
由于状态仅描述给定时刻的是,因此您必须自己处理此类事情。
对于这样的东西 - 弹出窗口或通知,你可以在同一个 Action 创建者中调度另一个 Action (如果你使用像 redux-thunk 这样的 thunk 中间件),它在 setTimeout
中创建弹出窗口,它将再撕下来。如果需要在不同时间或根据不同标准隐藏弹出窗口,则需要为每个弹出窗口存储值。
因此,对于给出的示例,您的操作创建器可能如下所示,其中组件 A 仅在 showPopupA1
为 true
时显示,而在 时从不显示错误
。这使一切都完全受状态控制,并避免了重新渲染时出现任何奇怪的问题。
export const showPopups = () => {
return dispatch => {
dispatch({
type: SHOW_POPUPS
})
// sets showPopupA, showPopupB to true
setTimeout(() => {
dispatch({
type: HIDE_POPUP_A
})
}, 5000)
// sets showPopupA to false
setTimeout(() => {
dispatch({
type: HIDE_POPUP_B
})
}, 10000)
// sets showPopupB to false
}
}
你需要使用像 redux-thunk 这样的中间件像这样分派(dispatch)多个 Action ,或者从 componentDidMount
中的弹出组件分派(dispatch) HIDE_POPUP Action 或其他东西,这只是稍微干净一些。
关于javascript - 使用 Redux 状态更改来触发不同 Web 组件中的一次性行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57485020/
我无法理解 XmlWriter 在 C# 中的工作方式。假设以下代码在某处使用过。 StringBuilder builder = new StringBuilder(); XmlWriterSett
两者的主要区别是什么 一次性 一次性观察者 复合 Material 一次性 何时使用它们中的每一个 最佳答案 Disposable 是可以取消的作业。CompositeDisposable 是一个父作
我使用 QML 列布局,但我只想禁用(或减少)两个元素之间的间距。其余之间的间距应单独保留。 这可能吗? 谢谢。 最佳答案 减少是困难的,但增加两个相邻项之间的间距很容易:只需在它们之间插入一个空的
我有一个“设置” View 和关联的 Controller ,在从源代码管理克隆站点后,我立即使用它们来配置 MVC 站点的数据库和 web.config。 运行一次后,我想防止“设置” Contro
我正在尝试从 Peter Seibel 的《Practical Common Lisp》一书中学习 Lisp。在 chapter 8 : "Macros: Defining your own" ,我遇
我正在实现一个从 Resource 发出行的可观察对象. 问题是这个资源真的不喜欢从创建它的不同线程关闭(它会杀死一只小狗并在发生这种情况时抛出异常)。 当我处理订阅时,资源 Cancellable/
假设我使用以下命令启动了一次性流程:heroku run:detached "node do-some-stuff.js" --app my-app命令的输出是这样的: /usr/local/hero
是否可以识别正在运行一次性 dyno(即 heroku run rails console)的用户(可能通过 Heroku 电子邮件)?用例自动将更改归因于该用户。 最佳答案 我认为这是不可能的,因为
前一段时间我使用 setup_environ() 编写了一个从命令行运行的一次性 python 脚本,它不太适合作为自定义 manage.py 命令(我的首选)。它很好地设置了一切。我假设我们弃用了这
当我使用 RXJava 1 时,我总是跟踪我的订阅以在 onDestroy Activity 中执行取消订阅。示例:https://medium.com/@scanarch/how-to-leak-m
在较旧的 MVC HTML 帮助程序中,可以使用 IDisposable 来包装内容 - 例如 BeginForm 帮助程序会自动包装 *stuff*带有结束 form 标记 *stuff*
我想使用 System.Threading.Timer 执行一次。该计时器应该在不再需要时(即回调触发时)通过调用 Dispose 来确定性地清理。 问题在于回调无法可靠地获取对 Timer 的引用!
我是 Angular 1.5 的新手,正在学习单向数据流的最佳实践。我要离开这个 jsfiddle,我真的很困惑特别是一种行为。 我理解数据从父级向下流向子级并且是单向绑定(bind)的,即子级的变化
我正在尝试抓取一个使用大量 ajax 效果在表格中显示数据的网站。 当您与网站交互时,会通过 JSON 返回一些数据。 我知道 URL 以及如何构造它,但如果我尝试重新请求此 JSON,服务器会返回
是否可以在一次性级触发模式下使用epoll? 当我搜索时,我找不到任何关于它的信息;好像大家都用边沿触发的方式。 最佳答案 When the EPOLLONESHOT flag is selected
在阅读了我能找到的关于延续的几乎所有内容后,我仍然无法理解它们。也许是因为所有的解释都与 lambda 演算密切相关,我很难理解。 通常,在您完成当前的事情(即计算的其余部分)之后,continuat
我有一个 block 的自定义实现,它的工作方式很像 Html.BeginForm() .实现基本如下: public class MyBlock : IDisposable { privat
我们有一个广泛的经典 ASP 站点,我们正在寻求升级到 ASP .Net(很可能是最新版本)。显然,一次升级所有页面将是一项艰巨的任务,因此我们一开始只希望在 ASP .Net 中编写新页面(和页面重
我有一个 Django 和 django 休息框架项目,我希望移动设备能够请求 token ,然后在断开连接之前使用该 token x 分钟。我不想为每个移动设备创建一个用户,我只想要一个一次性密码。
我正在通过 Forte.js 集成 ACH eCheck 付款。 文档说第一步是获取一次性安全 token ,我就是这样做的,使用 forte.js . 那么我应该将此 token 用于 REST A
我是一名优秀的程序员,十分优秀!