程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了在带有钩子的函数处理程序中使用 useRef大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决在带有钩子的函数处理程序中使用 useRef?

开发过程中遇到在带有钩子的函数处理程序中使用 useRef的问题如何解决?下面主要结合日常开发的经验,给出你关于在带有钩子的函数处理程序中使用 useRef的解决方法建议,希望对你解决在带有钩子的函数处理程序中使用 useRef有所启发或帮助;

我正在尝试提交一个发送 http 请求 onsubmit 的表单,但是在设置值的状态时我变得未定义。我不确定为什么这些值没有在点击时传递并使用 set...() 函数进行设置。

下面是那个组件的代码。在第一次提交操作时,我收到一个错误,因为“surveyUserAnswers”未定义,但在下一次提交中它起作用了。不知道为什么?有人可以建议。

我对打字稿和反应钩子很陌生,所以请原谅我的代码!谢谢

self.running_status = false

解决方法

设置状态是一个异步操作,更新后的状态只会在下一次渲染时可用。

在您的情况下,默认状态是 undefined,这是您在第一次提交时发送的内容。状态现在更新了,当你再次提交时,你发送之前的答案,依此类推...

为了解决这个问题,准备一个const(newAnswer),并将其设置为state,并在api调用中使用。

注意:就您而言,您根本没有使用 surveyUserAnswers,因此您可以完全删除此状态。

const onSubmitSurvey = (e: React.FormEvent): void => {
  e.preventDefault();
  setLoading((prevLoading) => !prevLoading);

  const newAnswer = {
    id: Math.random(),answers: [
      progrAMMerTypeQRef.current!.value,skillsQRef.current!.value,stateManagementQRef.current!.value,progrAMMerTypeQRef.current!.value,],}

  setSurveyUserAnswers(newAnswer);

  axios
    .post(`${DB_URL}/users-answers.json`,newAnswer)
    .then((res) => {
      setLoading((prevLoading) => !prevLoading);
    })
    .catch((error) => {
      console.log(error);
      setLoading((prevLoading) => !prevLoading);
    });
};

大佬总结

以上是大佬教程为你收集整理的在带有钩子的函数处理程序中使用 useRef全部内容,希望文章能够帮你解决在带有钩子的函数处理程序中使用 useRef所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:useRef