当前位置: 首页 > 知识库问答 >
问题:

在循环中声明的React js函数包含对变量“allowed”的不安全引用

谈桐
2023-03-14

收到此警告但代码正常工作循环中声明的函数包含对变量“allowed”的不安全引用如果我为allowed创建挂钩状态,则没有警告但代码不工作。如何在不使用useState的情况下声明变量。代码见附件。

const checkAllowed = async () => {
    let allowed = 1;
    await axios
      .get("http://localhost:4000/api/courses/eachstage/" + props.data.CourseID)
      .then(async (res) => {
        for (let i = 0; i < res.data.length; i++) {
          await axios
            .get("http://localhost:4000/api/courses/allow/" + res.data[i].StID)
            .then(async (response) => {
              if (response.data === 0) {
                allowed = 0;
              }
            });
        }
      });
    return allowed;
  };

共有2个答案

公羊俊
2023-03-14

我不确定你是否需要返回,但试试这个,稍微整洁一点,范围工作得更好

const checkAllowed = async () => {
    const { data } = await axios.get(`http://localhost:4000/api/courses/eachstage/${props.data.CourseID}`)
    const arrAllow = await Promise.all(data.map(async ({ StID }) => {
      return await axios.get(`http://localhost:4000/api/courses/allow/${StID}`)
    }))

    const allowFind = arrAllow.find((data) => data === 0)

    return !Boolean(allowFind) ? 1 : 0
  }
司马彬
2023-03-14

出现此警告是因为您在for循环之外声明allowed,然后在for循环中定义的函数内修改它)。这是不鼓励的,因为它的行为可能不像您期望的那样。

  1. 您可以在循环外部声明异步响应处理程序,并将其作为参数传入,而不是内联声明
  2. 您可以在结果上使用reduce,而不是for循环

您可能还希望不要在循环中等待,而是返回一个等待promise的promise数组。全部。这将允许您并行处理更多请求

更多详情请参见此处:https://eslint.org/docs/rules/no-loop-func

 类似资料:
  • 我的代码检查用户是否可用。请参见下面的片段: 我唯一的问题是它包含对变量的不安全引用,因为我得到以下错误: 我四处搜索并摆弄了我的代码,但我无法摆脱这个错误。我不知道去哪里找了。

  • 问题内容: 在循环内部声明变量是否不好?在我看来,这样做,如下面的第一个代码块所示,将使用第二次的十倍的内存…由于在循环的每次迭代中都创建了一个新的字符串。这样对吗? 与 问题答案: 在循环内部声明变量是否不好? 一点也不!它将变量本地化到其使用点。 在我看来,如下面的第一个代码块所示,这样做将使用十倍于第二个内存的内存。 编译器可以优化内容以保持内存使用效率。仅供参考:如果您使用关键字告诉您变量

  • 问题内容: 在Java中,我们不能与另一个具有相同名称的变量在同一作用域中声明一个变量: 语法错误,无法编译。但是,如果我们将其放入循环中: 不产生错误,效果很好。我们基本上是在声明相同的变量。是什么原因?在此背后我不知道/不了解的逻辑是什么? 问题答案: 考虑一下这种方式,在每个循环之后,作用域被“破坏”,变量消失了。在下一个循环中,将创建一个新的作用域,并且可以在该作用域中再次声明该变量。 由

  • 问题内容: 为什么以下工作正常? 但是据说这是危险的/不正确的: 是否需要在循环外声明变量? 问题答案: 局部变量的范围应始终尽可能小。 在你的例子我相信是不会使用的外while循环,否则你就不会问这个问题,因为它声明的内部while循环不会是一个选项,因为它不会编译。 所以,既然是不使用外循环,在尽可能小的范围是内 while循环。 所以,答案是着重那绝对应该被while循环内声明。没有,没有,

  • 问题内容: ja块变量还是局部变量?我看到j的作用域只是直到for循环结束 问题答案: 局部变量在方法,构造函数或块中声明。 由此可见, 所有块变量都是局部变量。 按照块的定义 块是平衡括号之间的一组零个或多个语句,可以在允许单个语句的任何地方使用。 所以 无论在块内声明什么变量,范围都限于该块。 因此范围仅限于该块内部。那是循环。

  • 问题内容: 我被困在我应该声明一个称为“ phrase”的字符串变量的部分,该变量不应一直循环播放。 让您知道我的任务是:与选项1相似,不同之处在于用户在输入第一队的结果后输入“ N”(而不是“ Q”)。然后,程序输入第二个团队名称及其结果,直到输入“ Q”。输出两个语句,例如选项1中的语句,然后输出第三条语句,该语句说明哪个团队处于第一位(基于点数) 输入样例: 样本输出: 更新 : 我的代码: