[英]How can I change only one value in a React useState that contains an object and assign a different one to the rest?
[英]how to merge into one object from different strings in useState?
我需要使用来自不同文本输入的不同数据写入值挂钩
const [value, setValue] = useState({
title: '',
url: '',
description: '',
});
<View style={styles.input_container}>
<TextInput
onChangeText={text => handleChange(text)}
value={value.title}
placeholder="enter book title"
/>
<TextInput
onChangeText={text => handleChange(text)}
value={value.url}
placeholder="link to book"
/>
<TextInput
onChangeText={text => handleChange(text)}
value={value.description}
placeholder="description"
/>
<Button title="add" onPress={pressHandler} />
</View>;
错误的处理程序
const handleChange = val => {
setValue({
value: {
title: val,
url: val,
description: val,
},
});
};
谢谢。
您可以使用指示来指示您指的是哪种键:
const handleChange = ({ type, text }) =>
setValue((prev) => ({ ...prev, [type]: text }));
const [value, setValue] = useState({
title: "",
url: "",
description: "",
});
<View style={styles.input_container}>
<TextInput
onChangeText={(text) => handleChange({ type: `title`, text })}
value={value.title}
placeholder="enter book title"
/>
<TextInput
onChangeText={(text) => handleChange({ type: `url`, text })}
value={value.url}
placeholder="link to book"
/>
<TextInput
onChangeText={(text) => handleChange({ type: `description`, text })}
value={value.description}
placeholder="description"
/>
<Button title="add" onPress={pressHandler} />
</View>;
如果你使用useState
钩子,你可以这样做。
const [title, setTitle] = useState(''); const [url, setUrl] = useState(''); const [description, setDescription] = useState(''); < View style = { styles.input_container } > < TextInput onChangeText = { text => setTitle(text) } value = { value.title } placeholder = "enter book title" / > < TextInput onChangeText = { text => setUrl(text) } value = { value.url } placeholder = "link to book" / > < TextInput onChangeText = { text => setDescription(text) } value = { value.description } placeholder = "description" / > < Button title = "add" onPress = { pressHandler } /> < / View >
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.