当前位置: 首页 > 面试题库 >

如何仅使用一次React useEffect调用加载函数

尹俊贤
2023-03-14
问题内容

该useEffect阵营钩将运行在功能上传递的每一个变化。可以对其进行优化,使其仅在所需属性更改时调用。

如果我想从中调用初始化函数componentDidMount而不在更改时再次调用该怎么办?假设我要加载一个实体,但是加载功能不需要组件中的任何数据。我们如何使用useEffect钩子做到这一点?

class MyComponent extends React.PureComponent {
    componentDidMount() {
        loadDataOnlyOnce();
    }
    render() { ... }
}

使用钩子可能看起来像这样:

function MyComponent() {
    useEffect(() => {
        loadDataOnlyOnce(); // this will fire on every change :(
    }, [...???]);
    return (...);
}

问题答案:

如果只想useEffect在初始渲染后运行给定的函数,则可以给它一个空数组作为第二个参数。

function MyComponent() {
  useEffect(() => {
    loadDataOnlyOnce();
  }, []);

  return <div> {/* ... */} </div>;
}


 类似资料:
  • 问题内容: 该useEffect阵营钩将运行在功能上传递的每一个变化。可以对其进行优化,使其仅在所需属性更改时调用。 如果我想从中调用初始化函数而不在更改时再次调用该怎么办?假设我要加载一个实体,但是加载功能不需要组件中的任何数据。我们如何使用钩子做到这一点? 使用钩子可能看起来像这样: 问题答案: 如果只想在初始渲染后运行给定的函数,则可以给它一个空数组作为第二个参数。

  • useEffect React钩子将在每次更改时运行传入函数。可以对此进行优化,使其仅在所需的属性更改时才调用。 如果我想从中调用初始化函数而不在更改时再次调用它,该怎么办?假设我想加载一个实体,但加载函数不需要组件的任何数据。我们如何使用钩子来实现这一点呢? 有了钩子,这可能是这样的:

  • 我是胡克斯的新手,遇到了一些让我追自己尾巴的案例。 希望有人能解释或提供对我有意义的解决方案: > 下面这个线程:如何调用加载函数与反应使用效果只有一次 我试着在没有依赖性的情况下使用useEffect,eslint不喜欢这样,他们建议添加一个“跳过下一行”,这似乎有点骇人:

  • 我很难理解如何只调用一次具有多个对象的函数(在for循环中)。 我试图写一个代码,其中对象的信息应该传递给另一个函数。 以下面的程序为例,函数被多次调用,而不是一次。 因为函数在循环中被调用了三次,所以一次只接受一个参数,而期望的输出应该是这样的: 那么,我如何一次调用函数,让它一次接受所有参数呢?感谢您的帮助。谢谢

  • 问题内容: 传统上,要在页面加载后调用JavaScript函数,您需要在包含一些JavaScript的正文中添加一个属性(通常只调用一个函数) 页面加载后,我想运行一些JavaScript代码以使用服务器中的数据动态填充页面的某些部分。因为我使用的是JSP片段,所以我无法使用该属性,而JSP片段没有可以添加属性的元素。 还有其他方法可以在加载时调用JavaScript函数吗?我宁愿不使用jQuer

  • 问题内容: 有没有办法调用从Swift的dylib加载的C函数? 这是我的 dylib 文件: cppdemofile.cpp cppdemofile.h 编译为dylib并检查: …复制到… Swift程序 : 如何调用该函数?可以使用dylib吗?我应该改为将这些资源添加到我的迅速项目中吗? 问题答案: 从Swift 调用该函数是可能的,因为您已将其定义为与C关联。 使库成为Swift模块(如