RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1432826
Accepted
Евгений Ключников
Евгений Ключников
Asked:2022-07-25 17:58:09 +0000 UTC2022-07-25 17:58:09 +0000 UTC 2022-07-25 17:58:09 +0000 UTC

做出反应。为什么计时器到期时按钮不切换回来?

  • 772

当我按下按钮时,它变为disabled。在计时器结束时,按钮应该再次处于活动状态,但这不会发生。为什么计时器到期后按钮不切换回来?我怀疑问题出在handleDisabled. 我把它放在那里并在函数中debugger看到了它。我做错了什么以及如何解决?itemhandleDisabled undefined

这是我的代码,包含所有必需的数据:

const CurrentEventsItem = () => {
    const [timeLeft, setTimeLeft] = useState( 15);
  
    const getPadTime = (time) => time.toString().padStart(2, "0");
  
    const minutes = getPadTime(Math.floor(timeLeft / 60));
    const seconds = getPadTime(timeLeft - minutes * 60);

    useEffect(() => {
        const interval = setInterval(() => {
          setTimeLeft((timeLeft) =>
            timeLeft >= 1 ? timeLeft - 1 : handleDisabled() || 15
          );
        }, 1000);
        return () => clearInterval(interval);
      }, []);
    
      const getRandomElements = (array, count) => {
        const shuffled = array.sort(() => 0.5 - Math.random());
        return shuffled.slice(0, count);
      };

    const [appState, changeState] = useState( [])

    useEffect(() => {
        getCurrentEvents()
      }, [])
    
      const getCurrentEvents = async() => {
        const data = await ProductDataService.getAllCurrentEvents()
        changeState(data.docs.map((doc) => ({...doc.data(), id: doc.id})))
      }

    const [selectedItems, setSelectedItems] = useState(() =>
        getRandomElements(appState, 3)
    );

    useEffect(() => {
        if (timeLeft === 0) {
          const elements = getRandomElements(appState, 3);
          setSelectedItems(elements);
        }
      }, [timeLeft, appState]);

    const toggleActiveStyles = (index) => {
        if (appState[index].statusItem) {
          return "current__events__hot-price disabled";
        } else {
          return "current__events__hot-price";
        }
      };
    
      const toggleActiveStylesBtns = (index) => {
        if (appState[index].statusItem) {
          return "current__events__btn-green disabled";
        } else {
          return "current__events__btn-green";
        }
      };
    
    const toggleActive = (item) => {
     item.statusItem = !item.statusItem;
     changeState([...appState]);
     setSelectedItems([...selectedItems]);
    };

    const handleDisabled = () => {
        appState.forEach((item) => {
          if (item.statusItem) {
            toggleActive(item);
          }
        });
    };

    return (
        <>
        <div className='current__events__wrapper'>
            {selectedItems.map((item, index) => 
                <div className="current__events__hot-price__item" key={index}>
                    <div className={toggleActiveStyles(index)}>
                        <h5 className="current__events__card-title__large">Hot Price</h5>
                    </div>
                    <div className="current__events__image">
                        <img src={item.avatar} alt='user' className="rounded-circle" width='75' height='75'/>
                    </div>
                    <div className="current__events__info">
                        <h4 className="current__events__title__middle">{item.title}</h4>
                    </div>
                    
                    <div className="current__events__timer">
                        <span>{minutes}</span>
                        <span>:</span>
                        <span>{seconds}</span>
                    </div>

                    <button className={toggleActiveStylesBtns(index)} onClick={() => toggleActive(item)} disabled={item.statusItem}>СДЕЛАТЬ ХОД</button> 
                </div> 
            )}

            
            </div>
        </>
    )
}
reactjs toggle
  • 1 1 个回答
  • 62 Views

1 个回答

  • Voted
  1. Best Answer
    EzioMercer
    2022-07-25T23:46:03Z2022-07-25T23:46:03Z

    老实说,我尝试更改代码很长时间,但我累了,只是按照您设置的条件一步一步地从头开始重写它。试图写出接近你的风格。有一件事非常令人困惑-这就是true您关闭按钮的原因。

    这是发生的事情:

    应用程序.js
    import { useState, useEffect } from 'react';
    import './styles.css';
    import CurrentEventsItem from './CurrentEventsItem';
    import ProductDataService from './productServices';
    
    export default function App() {
      const [items, setItems] = useState([]);
    
      useEffect(() => async () => await getCurrentEvents(), []);
    
      const getCurrentEvents = async () => {
        const data = await ProductDataService.getAllCurrentEvents();
    
        setItems(data.docs.map((doc) => ({ ...doc.data(), id: doc.id })));
      };
    
      return <CurrentEventsItem items={items} />;
    }
    
    CurrentEventsItem.js
    import { useState, useEffect } from "react";
    
    const getRandomElements = (array, count) => {
      const shuffled = array.sort(() => 0.5 - Math.random());
      return shuffled.slice(0, count);
    };
    
    const getPadTime = (time) => time.toString().padStart(2, "0");
    
    const CurrentEventsItem = ({items}) => {
      const [timeLeft, setTimeLeft] = useState(5);
      const [appState, changeState] = useState(items);
      const [selectedItems, setSelectedItems] = useState(getRandomElements(appState, 3));
    
      const minutes = getPadTime(Math.floor(timeLeft / 60));
      const seconds = getPadTime(timeLeft - minutes * 60);
    
      useEffect(() => {
        changeState(items);
        setSelectedItems(getRandomElements(items, 3));
      }, [items])
    
      useEffect(() => {
        const interval = setInterval(() => {
          setTimeLeft((timeLeft) => {
            if (timeLeft > 0) return timeLeft - 1;
    
            enableAll();
            setSelectedItems(getRandomElements(appState, 3));
    
            return 5;
          });
        }, 1000);
    
        return () => clearInterval(interval);
      }, [appState]);
    
      const toggleActiveStyles = (index) => `current__events__hot-price${
        appState[index].statusItem ? ' disabled' : ''
      }`;
    
      const toggleActiveStylesBtns = (index) => `current__events__btn-green${
        appState[index].statusItem ? ' disabled' : ''
      }`;
    
      const toggleActive = (item, activate = true) => {
        item.statusItem = activate;
      };
    
      const handleClick = (item) => {
        toggleActive(item);
        setSelectedItems([...selectedItems]);
      }
    
      const enableAll = () => {
        selectedItems.forEach(item => toggleActive(item, false));
        setSelectedItems([...selectedItems]);
      }
    
      return (
        <div className="current__events__wrapper">
            {selectedItems.map((item, index) => (
              <div className="current__events__hot-price__item" key={index}>
                <div className={toggleActiveStyles(index)}>
                  <h5 className="current__events__card-title__large">Hot Price</h5>
                </div>
                <div className="current__events__image">
                  <img
                    src={item.avatar}
                    alt="user"
                    className="rounded-circle"
                    width="75"
                    height="75"
                  />
                </div>
                <div className="current__events__info">
                  <h4 className="current__events__title__middle">{item.title}</h4>
                </div>
    
                <div className="current__events__timer">
                  <span>{minutes}</span>
                  <span>:</span>
                  <span>{seconds}</span>
                </div>
    
                <button
                  className={toggleActiveStylesBtns(index)}
                  onClick={() => handleClick(item)}
                  disabled={item.statusItem}
                >
                  СДЕЛАТЬ ХОД
                </button>
              </div>
            ))}
          </div>
      );
    };
    
    export default CurrentEventsItem;
    

    如果你有问题,那么问,我会解释我写了什么以及为什么写

    • 1

相关问题

  • 如果图像在道具中,如何使背景图像做出反应?

  • 项目未显示

  • 引发错误:InvalidTokenError: Invalid token specified: Cannot read property 'replace' of undefined

  • 如何在没有 node.js 的情况下运行 react.js 应用程序

  • 如何从 React Native 中的导航堆栈中清除上一个屏幕?

  • 为什么渲染后会触发 Click 事件?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5