首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >重置Recat本机中的初始状态值

重置Recat本机中的初始状态值
EN

Stack Overflow用户
提问于 2021-09-14 12:25:49
回答 2查看 56关注 0票数 0

要求:我必须用2种不同的颜色(除了红色和白色)眨眼2秒。我可以用这个代码-

代码语言:javascript
复制
    const [state, setState] = React.useState(false)
    const [initialState, setInitialState] = React.useState(0)

    React.useEffect(() => {
        if (initialState < 2){
            let interval = setInterval(() => {
                setState(true)
                setInitialState(initialState + 1)
                setTimeout(() => {
                    setState(false)
                }, 80);
            }, 300);
            setTimeout(() => {
                clearInterval(interval)
            }, 600);
        }
    }, [initialState])

把它叫做-

代码语言:javascript
复制
<View style={{...styles.mainContainer, backgroundColor: state ? Colors.GRO7 : Colors.GRC9}}>

另一个要求:我有另一个屏幕--我更改了地址,在成功更改地址时,我必须再次闪烁这个视图2秒。我不知道在哪里可以再次将初始值重置为0。

我是新的反应本土化的,有人能指导我如何实现这个功能吗?

EN

回答 2

Stack Overflow用户

发布于 2021-09-14 13:02:12

不能完全理解你的目标是什么。

这里是一个闪烁的文本示例

票数 0
EN

Stack Overflow用户

发布于 2021-09-14 14:49:24

您可以将初始值传递给此组件,而不是在该行中定义0:

代码语言:javascript
复制
const [initialState, setInitialState] = React.useState(0)

您可以传递一个param,并将其放入其中,而不是0,这样每当param更改时,这个组件都会重新呈现。所以你得到了一个新的初始状态。例如:

代码语言:javascript
复制
const [initialState, setInitialState] = React.useState(initialValue)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69177749

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档