首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React useEffect

React useEffect
EN

Stack Overflow用户
提问于 2020-07-21 05:22:44
回答 1查看 42关注 0票数 0

使用useEffect和dept []意味着它只需要setState一次,对吗?属性似乎到达得太晚了,因此我的单选按钮初始值没有突出显示

代码语言:javascript
复制
const [isOnlineSystem, setFutureOnlineSystem] = useState(null);
const [reasonType, setReasonType] = useState('');
const [customReason, setCustomReason] = useState('');

useEffect(() => {
    setFutureOnlineSystem(props.isFutureOnlineSystem)
}, []);

如果我使用下面的代码,它将设法赋值,当我打开我的模式表单时,单选按钮将突出显示,但我不希望它在每次组件更新时都设置值,因为该属性只到达一次

代码语言:javascript
复制
 useEffect(() => {
        setFutureOnlineSystem(props.isFutureOnlineSystem)
    }, [props.isFutureOnlineSystem]);

 <Radio.Group value={isOnlineSystem}
EN

回答 1

Stack Overflow用户

发布于 2020-07-21 05:28:28

代码语言:javascript
复制
const [isOnlineSystem, setFutureOnlineSystem] = useState(null);

不能将单选按钮值设置为空。它应该是

代码语言:javascript
复制
const [isOnlineSystem, setFutureOnlineSystem] = useState('');

使用useEffect和dept []意味着它只需要setState一次,对吗?

不是的。依赖关系意味着对于特定的deps,它将触发useEffect。

如果你把它留空了。这意味着它将在每次状态更改时触发,这是一种糟糕的做法。

更新:

代码语言:javascript
复制
const isInitial = useRef(true);

 useEffect(() => {
        if(isInitial) {

        setFutureOnlineSystem(props.isFutureOnlineSystem);
        isInitial.current = false;
       }
    }, [props.isFutureOnlineSystem, isInitial]);

这将只setState一次。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63003999

复制
相关文章

相似问题

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