如何解决在 React Native 中使用 useState
完全是一个初学者的问题,只是试图在按下按钮时增加一个变量,这是成功的尝试通过创建一个 if 语句来变得更有趣,当它达到 10 时,count 被设置回零,但似乎不起作用
App.js
import React,{ useState } from 'react';
import { Text,View,Button,StyleSheet} from 'react-native';
const HelloWorldApp = () => {
const [count,setCount] = useState(0);
const counter = () => {
if ( count > 10 )
{
count == 0;
}
setCount(count+1)
}
return (
<View style={{
flex: 1,justifyContent: 'center',alignItems: 'center'
}}>
<Text style={styles.baseText} >Hello,world! x{count}</Text>
<Button onPress={counter} title="Click me!"/>
</View>
);
}
const styles = StyleSheet.create({
baseText: {
fontFamily: "Cochin",fontSize: 20,fontWeight: "bold"
},});
export default HelloWorldApp;
解决方法
const counter = () => {
if ( count >= 10 )
{
setCount(0)
return
}
setCount(count+1)
}
,
您可以在 setCount 中检查条件..
import React,{ useState } from "react";
import { Text,View,Button,StyleSheet } from "react-native";
const HelloWorldApp = () => {
const [count,setCount] = useState(0);
const counter = () => {
setCount((prev) => (prev >= 10 ? 0 : prev + 1));
};
return (
<View
style={{
flex: 1,justifyContent: "center",alignItems: "center",}}
>
<Text style={styles.baseText}>Hello,world! x{count}</Text>
<Button onPress={counter} title="Click me!" />
</View>
);
};
const styles = StyleSheet.create({
baseText: {
fontFamily: "Cochin",fontSize: 20,fontWeight: "bold",},});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。