React Native useState setInterval 函数无法正常工作
React Native useState setInterval function not working properly
我正在尝试使用 RN 的 setState 和 setInterval 显示从 10 开始的倒计时计时器,然后每秒减少到 0。
我的视图正在更新,但计时器无法正常工作。它进行得非常快,并且在 9 - 0 之间随机跳跃。我的代码中也没有显示任何错误。
import { StyleSheet, Text } from 'react-native'
import React, {useState} from 'react'
export default function Timer() {
// Countdown timer logic upon click event
const [time, setTime] = useState(10)
setInterval(() => {
setTime(time => time > 0 ? time - 1 : time = 10)
},1000)
return (
<Text style={styles.timer}>{time}</Text>
)
}
const styles = StyleSheet.create({
timer: {
fontWeight: '700',
fontSize: 24,
color: '#00C261',
fontFamily: 'Roboto',
width: 30,
textAlign: 'center',
alignItems: 'center',
justifyContent: 'center'
}
})
至于现在,您在 每次渲染 上调用间隔(通过记录间隔进行检查),在几次渲染后出现“渲染竞赛”,而不是尝试将专用挂钩中的逻辑,因此间隔只会调用一次。
另请注意表达式 time = 10
returns 10
所以您的代码会出错,您应该将状态视为不可变的。
export default function Timer() {
const [time, setTime] = useState(10);
useEffect(() => {
const intervalID = setInterval(() => {
setTime((time) => (time > 0 ? time - 1 : 10));
}, 1000);
return () => {
clearInterval(intervalID);
};
}, []);
return <Text style={styles.timer}>{time}</Text>;
}
我正在尝试使用 RN 的 setState 和 setInterval 显示从 10 开始的倒计时计时器,然后每秒减少到 0。
我的视图正在更新,但计时器无法正常工作。它进行得非常快,并且在 9 - 0 之间随机跳跃。我的代码中也没有显示任何错误。
import { StyleSheet, Text } from 'react-native'
import React, {useState} from 'react'
export default function Timer() {
// Countdown timer logic upon click event
const [time, setTime] = useState(10)
setInterval(() => {
setTime(time => time > 0 ? time - 1 : time = 10)
},1000)
return (
<Text style={styles.timer}>{time}</Text>
)
}
const styles = StyleSheet.create({
timer: {
fontWeight: '700',
fontSize: 24,
color: '#00C261',
fontFamily: 'Roboto',
width: 30,
textAlign: 'center',
alignItems: 'center',
justifyContent: 'center'
}
})
至于现在,您在 每次渲染 上调用间隔(通过记录间隔进行检查),在几次渲染后出现“渲染竞赛”,而不是尝试将专用挂钩中的逻辑,因此间隔只会调用一次。
另请注意表达式 time = 10
returns 10
所以您的代码会出错,您应该将状态视为不可变的。
export default function Timer() {
const [time, setTime] = useState(10);
useEffect(() => {
const intervalID = setInterval(() => {
setTime((time) => (time > 0 ? time - 1 : 10));
}, 1000);
return () => {
clearInterval(intervalID);
};
}, []);
return <Text style={styles.timer}>{time}</Text>;
}