📱 Cross Platform/React Native
[React Native] TextInput과 Object를 useState로 바인딩 하는 법 (Binding a textinput with object)
Fomagran 💻
2022. 7. 26. 01:04
728x90
반응형
안녕하세요 Foma 입니다.
오늘은 TextInput 값에 따라 Object의 특정 프로퍼티 값이 바뀌는 것을 useState를 이용하여 구현하는 방법에 대해 정리해 보려고 합니다.
바로 시작할게요~
To do list
Todolist의 모델인 TodoModel이 있습니다.
interface TodoModel {
id: number;
author: string;
title: string;
content: string;
priority: number;
}
해당 Form의 인풋값에 따라 해당하는 TodoModel의 프로퍼티가 바뀌는 것을 구현하고 싶었는데요.
1. useState를 통해 TodoModel을 초기화 해줍니다.
const [todo, setTodo] = useState<TodoModel>({
author: '',
title: '',
content: '',
priority: 0,
});
2. input 값이 변화할 때 핸들링 하는 함수를 작성해 줍니다.
key와 value 파라미터로 받게 되는데 key는 TodoModel의 프로퍼티 이름, value는 해당 프로퍼티 값으로 새롭게 지정할 값을 의미합니다.
그 다음 ...prevState를 이용하여 기존의 프로퍼티 값을 유지하며, 해당 프로퍼티 값을 변경합니다.
const handleInputChange = (key: string, value: string) => {
setTodo(prevState => ({
...prevState,
[key]: value,
}));
};
3. TextInput의 onChangeText 메서드에 위 함수를 바인딩 해줍니다.
onChangeText를 통해 작성된 텍스트 값을 불러오고 해당 TextInput의 프로퍼티와 함께 handleInputChange에 전달해 줍니다.
<TextInput
value={todo.author}
onChangeText={text => {
handleInputChange('author', text);
}}
style={styles.input}
placeholder="author"></TextInput>
위와 같이 작성하고 todo 모델이 제대로 바뀌었는지 테스트 해주면
<Pressable onPress={() => console.log(todo)}>
<Text style={styles.button}> Submit </Text>
</Pressable>
아래와 같이 TextInput 값을 작성해 주고 Submit 버튼을 누르면
TextInput 내용대로 TodoModel 값이 출력되는 것을 볼 수 있습니다.
728x90
반응형