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

使React useEffect挂钩不在初始渲染上运行

应向晨
2023-03-14
问题内容

根据文档:

componentDidUpdate()更新发生后立即调用。初始渲染不调用此方法。

我们可以使用新的useEffect()钩子来模拟componentDidUpdate(),但似乎useEffect()在每次渲染后都被运行,即使是第一次也是如此。如何使它不在初始渲染上运行?

如您在下面的示例中看到的那样,它componentDidUpdateFunction是在初始渲染期间打印的,但componentDidUpdateClass在初始渲染期间没有打印的。

function ComponentDidUpdateFunction() {

  const [count, setCount] = React.useState(0);

  React.useEffect(() => {

    console.log("componentDidUpdateFunction");

  });



  return (

    <div>

      <p>componentDidUpdateFunction: {count} times</p>

      <button

        onClick={() => {

          setCount(count + 1);

        }}

      >

        Click Me

      </button>

    </div>

  );

}



class ComponentDidUpdateClass extends React.Component {

  constructor(props) {

    super(props);

    this.state = {

      count: 0,

    };

  }



  componentDidUpdate() {

    console.log("componentDidUpdateClass");

  }



  render() {

    return (

      <div>

        <p>componentDidUpdateClass: {this.state.count} times</p>

        <button

          onClick={() => {

            this.setState({ count: this.state.count + 1 });

          }}

        >

          Click Me

        </button>

      </div>

    );

  }

}



ReactDOM.render(

  <div>

    <ComponentDidUpdateFunction />

    <ComponentDidUpdateClass />

  </div>,

  document.querySelector("#app")

);


<script src="https://unpkg.com/react@16.7.0-alpha.0/umd/react.development.js"></script>

<script src="https://unpkg.com/react-dom@16.7.0-alpha.0/umd/react-dom.development.js"></script>



<div id="app"></div>

问题答案:

我们可以使用该useRef钩子来存储我们喜欢的任何可变值,因此我们可以使用它来跟踪useEffect函数是否是第一次运行。

如果我们希望效果在与该效果相同的阶段中运行componentDidUpdate,则可以使用useLayoutEffect

const { useState, useRef, useLayoutEffect } = React;



function ComponentDidUpdateFunction() {

  const [count, setCount] = useState(0);



  const firstUpdate = useRef(true);

  useLayoutEffect(() => {

    if (firstUpdate.current) {

      firstUpdate.current = false;

      return;

    }



    console.log("componentDidUpdateFunction");

  });



  return (

    <div>

      <p>componentDidUpdateFunction: {count} times</p>

      <button

        onClick={() => {

          setCount(count + 1);

        }}

      >

        Click Me

      </button>

    </div>

  );

}



ReactDOM.render(

  <ComponentDidUpdateFunction />,

  document.getElementById("app")

);


<script src="https://unpkg.com/react@16.7.0-alpha.0/umd/react.development.js"></script>

<script src="https://unpkg.com/react-dom@16.7.0-alpha.0/umd/react-dom.development.js"></script>



<div id="app"></div>


 类似资料:
  • 根据文件: 在更新发生后立即调用。初始渲染时不调用此方法。 我们可以使用新的钩子来模拟,但是每次渲染后,甚至第一次渲染后都会运行。如何使其不在初始渲染时运行? 正如您在下面的示例中所看到的,在初始渲染过程中打印了,但是在初始渲染过程中没有打印。

  • 我有一个使用输入钩子组件,其工作原理如下: 它获取一个(input,inputName)并返回一个挂钩的输入组件。当我想动态地改变视图中现有输入的可见性时,我得到一个错误:渲染的钩子比之前渲染的多。

  • 今天遇到了钩子的问题。我知道有一个类似的帖子,我阅读了使用钩子的规则。现在,当我发布表单时,它给了我这个错误。我知道这是因为我的钩子在if语句里面。但是我怎样才能把它弄出来呢?我不知道如果它不在函数或语句中,那么如何使用这个钩子。任何建议将不胜感激。代码如下: 自定义挂钩:

  • 可以通过appear特性设置节点在初始渲染的过渡: <transition appear> <!-- ... --> </transition> 这里默认和进入/离开过渡一样,同样也可以自定义 CSS 类名。 <transition appear appear-class="custom-appear-class" appear-to-class="custom-appear

  • 我目前正在处理一个注册表单,以下是我的代码片段: 每个状态都用于表单的受控输入。 基本上,我想做的是在用户成功注册后,我希望状态返回到初始状态,并清除字段。 在中手动将每个状态设置回空字符串是非常必要的。我想知道React是否有一个方法或函数可以将状态重置回初始值?

  • 如何将 2 个 graphql 查询与 react-apollo-hooks 结合使用,其中第 2 个查询依赖于从第 1 个查询中检索到的参数? 我尝试使用如下所示的两个查询: 然而,当我运行我的项目时,react-hooks给我以下消息: " index.js:1437警告:React检测到Upgrade调用的挂钩顺序发生了变化。如果不修复,这将导致错误和错误。有关更多信息,请阅读“挂钩规则”