首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何修复在属性更改时使用useEffect挂钩更新状态时出现的缺少依赖项警告

如何修复在属性更改时使用useEffect挂钩更新状态时出现的缺少依赖项警告
EN

Stack Overflow用户
提问于 2020-10-29 11:12:08
回答 1查看 22关注 0票数 1

我的组件有三个属性。urlText是一个字符串,setSelectedText是从connect()和clearPage更新状态的redux操作,后者是清除状态的另一个redux操作。

我只想在urlText更改时更新状态。我想在卸载时清除状态。

代码语言:javascript
运行
复制
 I get this eslint warning `react-hooks/exhaustive-deps: React Hook useEffect has missing dependencies: setSelectedText`

 warning `react-hooks/exhaustive-deps: React Hook useEffect has missing dependencies: clearPage`


const Component = ({ urlText, setSelectedText, clearPage }) => {
  useEffect(() => {
    setSelectedText(urlText);
  }, [urlText]);

  useEffect(() => {
    return () => {
      clearPage();
    };
  }, []);
};
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-29 11:13:25

它不会对您的脚本运行方式产生任何影响,但linter警告您将其更改为:

代码语言:javascript
运行
复制
useEffect(() => {
    setSelectedText(
        urlText
    );
}, [setSelectedText, urlText]);

useEffect(() => {
    return () => {
        clearPage();
    };
}, [clearPage]);

虽然最后一个可以简化为:

代码语言:javascript
运行
复制
useEffect(() => clearPage, clearPage);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64584439

复制
相关文章

相似问题

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