gpt4 book ai didi

javascript - React Native 按钮不会改变状态

转载 作者:行者123 更新时间:2023-11-28 17:06:02 25 4
gpt4 key购买 nike

按下代码中指定的按钮后,我的应用程序的状态不会改变。

import React from 'react'
import { View, Text, TextInput, Button} from 'react-native'

export default class App extends React.Component {
constructor() {
super()
this.state = {
text: '',
displayText: true
}
}

render() {
return (
<View>
<TextInput
onChangeText={(text) => this.setState({text})}
/>
<Button
onPress={(prevState) => this.setState({displayText: !prevState.displayText})}
title="Display"
/>
{this.state.displayText ? <Text>{this.state.text}</Text> : null}
</View>
)
}

}

如果传递给 onPress 的函数经过修改,将 displayText 更改为 false,则它会按预期工作(隐藏文本)。问题很可能出在这部分。

<Button
onPress={(prevState) => this.setState({displayText: !prevState.displayText})}
title="Display"
/>

最佳答案

<Button
onPress={(prevState) => this.setState({displayText: !prevState.displayText})}
title="Display"
/>

这是错误的,prevState 参数来自 setState 作为函数,而不是来自 onPress 事件:)

应该是

<Button
onPress={() => this.setState({displayText: !this.state.displayText})}
title="Display"
/>

<Button
onPress={() => this.setState(prevState => {displayText: !prevState.displayText})}
title="Display"
/>

关于javascript - React Native 按钮不会改变状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55828431/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com