【问题标题】:Passing updated state from parent to child将更新的状态从父母传递给孩子
【发布时间】:2021-06-08 15:58:57
【问题描述】:

我在我的父组件中创建了一个带有布尔值 false 的 let 变量。我将该变量作为道具传递给子组件。我通过父组件中的函数将变量更改为 true。 我的问题是子组件中prop的值在我console.log之后仍然是false。

家长:

function App() {
 
  let success = false
  
 
  const changePW = async ({password, repeatPW}) => {


    success = true
    console.log(`Success App0: ${success}`)
    console.log('ChangePW')

  return (
    <BrowserRouter>
    <div className="container">
      <Header/>
      <Route path='/' exact render={(props) => (
        <>
          <AddPasswort onChange = {changePW} success = {success}/>
          <Footer />
        </>
       )}/>
       
      <Route path='/about' component={About} />
      
      <Route path='/success' component={Success} />
      <Route path='/error' component={Error} />
      
      
      </div>
    </BrowserRouter>
  
  );
}

export default App;

孩子

const AddPasswort = ({onChange,success}) => {
    const[password, setPassword] = useState('')
    const[repeatPW, setRepeatPW] = useState('')
    
    // create a history object 
    const history = useHistory()  
   

    const onSubmit = async (e) => {
        e.preventDefault();

     
            await onChange({password, repeatPW})
            console.log(success)
            // navigate to the success page 
            if (success){
                console.log('success')
                history.push("/success")
            }
            else{
                console.log('error')
                history.push("/error")
            }    
        }


    }
    ...
   
}

export default withRouter(AddPasswort);

我认为问题在于该函数没有等待 onChange 完成,所以我将其设为异步,但这并没有解决问题

【问题讨论】:

  • 您需要触发重新渲染并保持更改。您是否将该值存储在 state 中?请贴出相关代码
  • 这样做了。感谢您愿意提供帮助。

标签: reactjs


【解决方案1】:

因为成功不是一种状态, 只有改变状态才会重新渲染组件。 试试

const [success, setSuccess] = useState(false);

要将 success 的值更改为 true ,请执行

setState(true)

这应该可以解决您的问题

【讨论】:

  • 我这样做了,但由于某种原因状态不会改变。现在,即使是父组件中的 console.log 也会打印出 false。不知道为什么状态不改变 setSuccess(true) console.log(Success App0: ${success})//还是假的
猜你喜欢
  • 2018-06-29
  • 2020-04-06
  • 2019-05-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-07-22
  • 2018-08-04
  • 2017-01-17
相关资源
最近更新 更多