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

React:setState()挂钩,未设置初始颜色

赵佐
2023-03-14

我试图设置一个基本的喜欢项目,类似于facebook喜欢当页面第一次呈现时是黑色的颜色,然后使用React钩子,useState()和use效应()来改变喜欢状态变化时的颜色。然而,我已经得到了渲染的颜色,但是它也在加载渲染,所以当用户点击“喜欢”并改变喜欢状态时,不会从黑色变成绿色。

import React, { useState, useEffect } from "react";

function Update() {
  **const [like, updateLikes] = useState(0);
  const [dislike, updateDislikes] = useState(0);
  const [likeColor, setLikeColor] = useState("black");
  const [dislikeColor, setDislikeColor] = useState("black");
  useEffect(() => {
    setLikeColor("green");
  }, [like]);
  useEffect(() => {
    setDislikeColor("red");
  }, [dislike]);**

  return (
    <div className="updateDiv">
      <span className="update">
        <img className="profilePic" src="https://picsum.photos/50/50" alt="" />
        <div className="name">Username</div>
        <div className="time">08:30am</div>
        <div className="text">Reading a good book!</div>
        <div className="likes">
          Likes:
          **<p style={{ color: likeColor }}>{like}</p>**
        </div>
        <div className="dislikes">
          Dislikes:
          <p style={{ color: dislikeColor }}>{dislike}</p>
        </div>
        <button type="submit" onClick={() => updateLikes(like + 1)}>
          Like
        </button>
        <button type="submit" onClick={() => updateDislikes(dislike + 1)}>
          Dislike
        </button>
        <hr />
      </span>
    </div>
  );
}

export default Update;

所以,我想要类似的初始颜色

可能是一个快速解决方案,但我开始把头撞到墙上:D


共有2个答案

商和颂
2023-03-14

因为您正在useEffect挂钩下调用setLikeColor和setDislikeColor,并且最初useEffect正在运行并更改颜色。您可以执行以下操作:

import React, { useState, useEffect } from "react";

function Update() {
  const [like, updateLikes] = useState(0);
  const [dislike, updateDislikes] = useState(0);
  const [likeColor, setLikeColor] = useState("black");
  const [dislikeColor, setDislikeColor] = useState("black");
  useEffect(() => {
    console.log("useEffect");

    if (like > 0) {
      setLikeColor("green");
    }
  }, [like]);
  useEffect(() => {
    if (dislike > 0) {
      setDislikeColor("red");
    }
  }, [dislike]);

  return (
    <div className="updateDiv">
      <span className="update">
        <img className="profilePic" src="https://picsum.photos/50/50" alt="" />
        <div className="name">Username</div>
        <div className="time">08:30am</div>
        <div className="text">Reading a good book!</div>
        <div className="likes">
          Likes:<p style={{ color: likeColor }}>{like}</p>
        </div>
        <div className="dislikes">
          Dislikes:
          <p style={{ color: dislikeColor }}>{dislike}</p>
        </div>
        <button type="submit" onClick={() => updateLikes(like + 1)}>
          Like
        </button>
        <button type="submit" onClick={() => updateDislikes(dislike + 1)}>
          Dislike
        </button>
        <hr />
      </span>
    </div>
  );
}

export default Update;
吕承福
2023-03-14

useEffect挂钩也将在挂载上运行。因此,需要防止钩子在第一次渲染时设置颜色。

您可以通过使用userefhook来实现这一点。

const mountRef = useRef(false);

useEffect(() => {
  if (mountRef.current) {
    setLikeColor("green");
  }
  else {
   mountRef.current = true;
  }     
}, like);
 类似资料:
  • 我目前正在处理一个注册表单,以下是我的代码片段: 每个状态都用于表单的受控输入。 基本上,我想做的是在用户成功注册后,我希望状态返回到初始状态,并清除字段。 在中手动将每个状态设置回空字符串是非常必要的。我想知道React是否有一个方法或函数可以将状态重置回初始值?

  • 当安装完成并首次启动 Navicat Monitor 时,浏览器会弹出并打开你的 Navicat Monitor 的网址“http://<your_ip_address>:<port_number>”。你需要在欢迎页面完成 Navicat Monitor 的基本配置。 【注意】<your_host_address> 是安装了 Navicat Monitor 的系统的主机名,以及 <port_num

  • 我一直得到 完整的堆栈跟踪是: 我已经找到了解决方案,找到了一堆。 无法初始化类网络。旧金山。jasperreports。发动机util。JRStyledTextParser 还有大约10个(这是我的第一个问题,所以我不可能把他们都包括在内)。 我试过: 设置 我在代码内做到了: (按预期返回true)。 我将CATALINA_选项设置为。回响如预期。 这没用。 我试了一下。带有DejaVu SA

  • 设置初始 被选中国家 。当Gio地球完成初始化之后,地球会有一个转动动画,将初始国家转至屏幕正前方。 默认设置下初始国家是"CN"(中国)。 默认初始国家: // 将初始国家改成"美国" controller.setInitCountry("US");

  • 我开始使用钩子,我遇到了一个问题。 我有一个状态: 最初设置为,它在初始渲染时正确渲染。 但问题是,我希望它的值是我使用hook在初始渲染中获取的数组的长度 但是我不知道阵列的长度,直到组件安装完毕。 所以,在这个函数中,我试图访问priceToFilter,但它返回,因为这是它的初始值。 但是,如果您在中看到,我将通过函数将设置为另一个值。但是,当发生在初始化挂载之后时,它不会获得新值,而是保持

  • 问题内容: 根据文档: 更新发生后立即调用。初始渲染不调用此方法。 我们可以使用新的钩子来模拟,但似乎在每次渲染后都被运行,即使是第一次也是如此。如何使它不在初始渲染上运行? 如您在下面的示例中看到的那样,它是在初始渲染期间打印的,但在初始渲染期间没有打印的。 问题答案: 我们可以使用该钩子来存储我们喜欢的任何可变值,因此我们可以使用它来跟踪函数是否是第一次运行。 如果我们希望效果在与该效果相同的