본문 바로가기

React

React Native / 메모장 만들기 sample (useEffect, AsyncStorage )

반응형

간단하게 메모를 한 후에 저장 후, 해당 저장한 내용을 불러오는 메모장 만들기를 연습삼아 해보았다.

 

(참고사이트)

https://www.youtube.com/watch?v=1mkgX7Mr5fI

 

 

 

 

App.js

import { StatusBar } from 'expo-status-bar';
import React, {useEffect, useLayoutEffect, useState}from 'react';
import { StyleSheet, Text, View,SafeAreaView, Button, TextInput } from 'react-native';
import AsyncStorage from '@react-native-async-storage/async-storage';

export default function App() {

  const [txt, setTxt] = useState('안녕하세요')

  //처음 자동으로 실행하게 해주는 hook : useEffect
  useEffect(() => {
    //console.log('프로그램 시작');   
    loadData(); 
  }, []);



  // 데이터를 app에 저장
  const saveData = async (value) => {
    try {
      await AsyncStorage.setItem('assa', value)
      //await : 내용이 얼마나 될지 모르니까 비동기통신을 기다림
      //AsyncStorage.setItem('@storage_Key', value) :@storage_Key 아무변수나 넣어도 됨, but 불러올때도 같은 이름이여야함 
      console.log('저장');

    } catch (e) {
      // saving error
    }
  }

  // 데이터를 app에서 불러옴
  const loadData = async () => {
    try {
      const value = await AsyncStorage.getItem('assa')
      console.log('불러오기');

      if(value !== null) {
        // value previously stored
        setTxt(value);
      }
    } catch(e) {
      // error reading value
    }
  }



  return (
    <View style={{ flex:1, backgroundColor:'#fc0'}}>
      <SafeAreaView style={{ flex:1,  }}>
        <StatusBar style="auto" />
        <View style={{padding:10, flexDirection:'row', 
                      alignItems:'center', justifyContent:'space-between'}}>
          <Button title="저장" onPress={()=>saveData(txt)}></Button>
          <Text style={{fontSize:18}}> 메모장 </Text>
          <Button title="불러오기"  onPress={()=>loadData()}></Button>
        </View>
      <View style={{backgroundColor:'#eeeeee', flex:1, padding:10}}>
        <TextInput value={txt} 
                    multiline //여러줄 입력가능하도록 하는 것
                   onChangeText={txt => setTxt(txt)}//textInput에서 값을 바꿀수 있도록
                  />
      </View>
    </SafeAreaView>
   </View>
  );
}

 

 

 

 

💡AsyncStorage 사용방법

  •   AsyncStorage란? / 앱에 데이터 저장 (Async : 비동기)

 

 

1. Install 

expo install @react-native-async-storage/async-storage

 

2. Import

import AsyncStorage from '@react-native-async-storage/async-storage';

 

3. Usage

 

데이터를 App에 저장 

const storeData = async (value) => {
  try {
    await AsyncStorage.setItem('@storage_Key', value)
  } catch (e) {
    // saving error
  }
}

 

데이터를 App에서 불러옴

const getData = async () => {
  try {
    const value = await AsyncStorage.getItem('@storage_Key')
    if(value !== null) {
      // value previously stored
    }
  } catch(e) {
    // error reading value
  }
}

 

 

💡UseEffect

  •  React Native의 hook의 일종으로 리액트에게 컴포넌트가 렌더링 된 이후에 수행해야하는 일을 말해줌

 

 

(왼) 내용 입력 후 저장버튼 클릭 / (가) input박스 비우기 / (오) 불러오기 버튼 클릭 후

 

반응형