- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Action 创建器,它会进行昂贵的计算并在每次用户输入内容时分派(dispatch)一个 Action (基本上是实时更新)。但是,如果用户输入多个内容,我不希望之前的昂贵计算完全运行。理想情况下,我希望能够取消之前计算的执行,只执行当前计算。
最佳答案
没有内置功能可以取消 Promise在异步操作中。如果您使用 AJAX 请求,您可以尝试手动实现取消,但是,如果您使用 Fetch API,则不可能。 (关于添加此功能的讨论正在进行 here )。
然而,我建议做的是,不要在每次用户在字段中键入内容时分派(dispatch)昂贵的操作,而是将去抖动功能应用于您的事件处理功能。这个函数在很多库中都有:
这将延迟调度 Action ,直到自上次调度该 Action 以来经过一定的毫秒数。它将大大减少大量繁重的异步操作,因为将分派(dispatch)操作,比方说,每 500 毫秒或 1 秒取决于您的配置而不是每个更改事件。
lodash 的实现示例:
class MyComponent extends React.Component {
constructor() {
// Create a debounced function
this.onChangeDelayed = _.debounce(this.onChange, 500);
}
onChange() {
this.props.onChange(); // Function that dispatches an action
}
render() {
return (<input type="text" onChange={this.onChangeDelayed} />);
}
}
关于javascript - 如何取消执行新 Action 时执行的先前 Action ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41205245/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!