我只是在学习如何应对并遇到问题.我正在制作一组计数器组件,如下所示:

this is the counters that I'm making

问题是,我已经在每个计数器中定义了状态,即其中的3个计数器,我想将值(数字)传递到父计数器中,以便将其相加并显示总计数.

这是我的子元素计数器组件:

import React, { useState } from "react";
const Counter = () => {
    const [count, setcount] = useState(0)
    const handleIncrement=()=>{

        setcount(count+1);
    }
    const handleDecrement=()=>{

        setcount(count+-1);
    }

  return (
    <div>
      <button onClick={()=>{handleIncrement()}}>+</button>
      <span>{count}</span>
      <button onClick={()=>{handleDecrement()}}>-</button>
    </div>
  );
};

export default Counter;

这是我要将值传递给的父级,以便我可以将它们相加并显示总数:

import React from 'react'
import Counter from './Counter'
const Counters = () => {
  return (
    <>
    <h3>totalcount:</h3>
    <Counter/>
    <Counter/> 
    <Counter/> 

    </>
  )
  
}

export default Counters

我试着做了多个状态,但我找不到一个好方法.我知道这有一个简单的答案,我把它弄得太复杂了.如果你们对我的代码有其他优化,请分享.

推荐答案

在React状态下,从上到下.如果父级中定义的函数已作为props 传递给嵌套组件,则嵌套组件可以更新父级的状态.也就是说,你想做的事情是不可能的,因为你的代码已经设置好了.实现您所追求的目标的一种方法是:

import React, { useState } from "react";
const Counter = ({count, setCount}) => {
  
    const handleIncrement=()=>{
        setCount(count+1);
    }
    const handleDecrement=()=>{
        setCount(count+-1);
    }

  return (
    <div>
      <button onClick={()=>{handleIncrement()}}>+</button>
      <span>{count}</span>
      <button onClick={()=>{handleDecrement()}}>-</button>
    </div>
  );
};

export default Counter;
import React, { useState } from 'react'
import Counter from './Counter'
const Counters = () => {
  const [countOne, setCountOne] = useState(0)
  const [countTwo, setCountTwo] = useState(0)
  const [countThree, setCountThree] = useState(0)
  return (
    <>
    <h3>totalcount: {countOne + countTwo countThree} </h3>
    <Counter count = {countOne} setCount = {setCountOne} />
    <Counter count = {countTwo} setCount = {setCount} />
    <Counter count = {countThree} setCount = {setCountThree} />

    </>
  )
  
}

export default Counters

Javascript相关问答推荐

reaction useEffect KeyDown for each 条目配音输出

仅在React和JS中生成深色

为什么JavaScript双边字符串文字插值不是二次的?

获取加载失败:获取[.]添加时try 将文档添加到Firerestore,Nuxt 3

如何在不分配整个数组的情况下修改包含数组的行为主体?

Bootstrap动态选项卡在切换选项卡后保持活动状态,导致元素堆叠

react/redux中的formData在expressjs中返回未定义的req.params.id

引用在HTMLAttributes<;HTMLDivElement>;中不可用

如何从URL获取令牌?

简单的PayPal按钮集成导致404错误

更新动态数据中对象或数组中的所有值字符串

AJAX POST在控制器中返回空(ASP.NET MVC)

用于部分字符串的JavaScript数组搜索

如何在脚本编译后直接将RxJ模块导入浏览器(无需Angel、webpack、LiteServer)

如果NetSuite中为空,则限制筛选

有没有办法通过使用不同数组中的值进行排序

将Singleton实例设置为未定义后的Angular 变量引用持久性行为

Chrome上的印度时区名S有问题吗?

如何在css中裁剪成一定Angular 的圆的一部分,而不需要复杂的多边形

Google OAuth 2.0库和跨域开放程序的问题-策略错误