- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用按钮构建计时器,单击以启动和停止计时器。我一直在尝试不同的方法并阅读 StackOverflow 过去的问题,但仍然无法让它在我的应用程序上运行。我已经设置了applyMiddleware(thunk)
到商店。
基本上我有一个按钮
<button onClick={props.timerHandler}>
{props.isRunning ? "TIMER STOP" : "TIMER START"}
</button>
props.timerHandler
是将 isRunning 值更改为 true 和 false。
case "TIMER":
let timer = null;
clearInterval(timer);
if (state.isRunning === true)
timer = setInterval(() => {
return state + 1;
}, 1000);
return {
...state,
isRunning: !state.isRunning,
};
在实践中,我尝试了这样的代码,并导出以在我的 App.js 中使用,但也无法正常工作。
export const timer = () => (dispatch, getState) => {
let timer = null;
clearInterval(timer);
if (getState().isRunning === true)
timer = setInterval(() => {
dispatch(incAction());
}, 1000);
};
请帮忙,如果需要澄清,请告诉我。谢谢
最佳答案
您应该将副作用放在 thunk 中,而不是放在 reducer 中,因为 reducer 必须是同步纯函数。
以下是处理 thunk 中的副作用的示例:
const { Provider, useDispatch, useSelector } = ReactRedux;
const { createStore, applyMiddleware, compose } = Redux;
const { createSelector } = Reselect;
const initialState = {
timer: { isRunning: false, time: 0 },
};
//selectors
const selectTimer = (state) => state.timer;
const selectIsRunning = createSelector(
[selectTimer],
(timer) => timer.isRunning
);
const selectTime = createSelector(
[selectTimer],
(timer) => timer.time
);
//action types
const TOGGLE = 'TOGGLE';
const UPDATE = 'UPDATE';
//action creators
const toggle = () => ({ type: TOGGLE });
const update = () => ({ type: UPDATE });
//thunks
const toggleTimer = () => (dispatch, getState) => {
dispatch(toggle());
const isRunning = selectIsRunning(getState());
if (isRunning) {
dispatch(recurUpdate());
}
};
const recurUpdate = () => (dispatch, getState) =>
setTimeout(() => {
const isRunning = selectIsRunning(getState());
if (isRunning) {
dispatch(update());
//recursively dispatch this thunk
dispatch(recurUpdate());
}
}, 1000);
const reducer = (state, { type }) => {
if (type === TOGGLE) {
return {
...state,
timer: {
...state.timer,
isRunning: !state.timer.isRunning,
},
};
}
if (type === UPDATE) {
return {
...state,
timer: { ...state.timer, time: state.timer.time + 1 },
};
}
return state;
};
//creating store with redux dev tools
const composeEnhancers =
window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;
const store = createStore(
reducer,
initialState,
composeEnhancers(
applyMiddleware(
({ dispatch, getState }) =>
(next) =>
(
action //simple thunk implementation
) =>
typeof action === 'function'
? action(dispatch, getState)
: next(action)
)
)
);
const App = () => {
const dispatch = useDispatch();
const isRunning = useSelector(selectIsRunning);
const time = useSelector(selectTime);
const timerHandler = React.useCallback(
() => dispatch(toggleTimer()),
[dispatch]
);
return (
<div>
<button onClick={timerHandler}>
{isRunning ? 'TIMER STOP' : 'TIMER START'}
</button>
Time:{time}
</div>
);
};
ReactDOM.render(
<Provider store={store}>
<App />
</Provider>,
document.getElementById('root')
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.8.4/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.8.4/umd/react-dom.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/redux/4.0.5/redux.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-redux/7.2.0/react-redux.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/reselect/4.0.0/reselect.min.js"></script>
<div id="root"></div>
关于javascript - 使用 Redux Middleware Thunk 构建计时器(setInterval 和 clearInterval),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69067976/
这个问题已经有答案了: JavaScript closure inside loops – simple practical example (45 个回答) 已关闭 8 年前。 我试图创建多个 se
这是我的情况,我需要加快函数运行时间,所以 setInterval 不是一个明智的选择,对吧?因为每次至少要花费 4 毫秒。 所以,我可以将 setInterval 函数更改为 requestAnim
我正在尝试下面的代码,看看是否可以将 setInterval Id 存储为关联数组中唯一键的值,然后通过使用唯一值作为键来停止被调用函数中的间隔,如下所示我将 setInterval Id 作为它的值
我花了很长时间试图弄清楚如何使用具有 CSS 样式缓动功能的 Google Maps API 为折线上的符号设置动画。我让它工作 with this Gist和 this Google Maps AP
我是这里的 JS 新手,正在研究一个在给定时间段后开始的倒数计时器。基本上,当用户单击按钮时时钟开始,第二个时钟在第一个计时器用完时开始。我知道“setInterval”是完成这个的最好方法。我面临的
嗨, friend 们,我想只使用一个 setInterval 函数来运行我的代码。目前我正在使用两个 setInterval's 来实现我的目标,我们可以只使用一个 'setInterval' 来获
我的“setInterval”函数有问题,我想在将鼠标悬停在 div 上时启动该函数,但是 setInterval 在我将鼠标悬停在 div 上时第一次起作用=>如果我停留在div,它不会继续改变图片
我想展示两次:一次在你的国家,一次在日本用JS 问题是第二个 setInterval 停止了第一个,我不知道如何进行两次运行。 完整代码 In your region:
好吧,这个问题有几个问题。 首先,我要求 setTimeout() 和 setInterval() 我见过几种不同的调用方式,我想知道哪种方式最适合这种情况。 我正在制作一个 js/canvas 游戏
setInterval(function () { //======= //code //======== if(--timer&etype="; } },1000); 这里定时器结束后,而不是重定
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 5 年前。 Improv
我的前老板有一个 weird bug where when he used setInterval with a long delay interval : setInterval(func, 300
这个问题已经有答案了: How does the "this" keyword work, and when should it be used? (22 个回答) How to access the
我的印象是 setInterval("/*some code*/", time) 相当于 setInterval(function() { /*some code*/ }, time) 显然不是
我对 JavaScript 和 NodeJS 非常陌生,我只是想了解 NodeJS 中的发射器模式。当我尝试使用 setInterval 函数每秒发出一个刻度事件时,程序似乎工作正常:-
我有一个简单的 setTimeout 函数,它在特定时间运行并且工作正常: var now = new Date(); var milliTillExec = new Date(now.getFull
在本教程中,您将借助示例了解 JavaScript setInterval() 方法。 在 JavaScript 中,可以在指定的时间间隔内执行一段代码。这些时间间隔称为定时事件。 有
Js: function cometConnect(){ $.ajax({ cache:false, type:"post", d
LE2。关于如何解决此问题的任何其他想法? 我有这段代码,但不知道为什么不能正常工作: $(function autorun() { if ($("#contactForm").is(":visibl
这个问题在这里已经有了答案: How to make a setInterval stop after some time or after a number of actions? (6 个答案)
我是一名优秀的程序员,十分优秀!