[RN 3-1 프로젝트 준비]

2020. 2. 21. 22:40React Native/React Native 일정관리 앱

반응형

1. 리액트 네이티브 CLI 명령어를 사용하여 할 일 리스트 프로젝트를 생성

react-native init TodoList



2. 개발을 좀 더 편리하게 하기 위해 타입스크립트, Styled Components, babel-pluginroot-import를 다음 명령어로 설치

cd TodoList 
npm install --save styled-components 
npm install --save-dev typescript @types/react @types/react-native @types/styled-components babel-plugin-root-import 


3. IDE 를 실행하여 프로젝트 오픈하여 타입스크립트 생성 및 설정 : tsconfig.json

더보기
{ 
  "compilerOptions": { 
    "allowJs": true, 
    "allowSyntheticDefaultImports": true, 
    "esModuleInterop": true, 
    "isolatedModules": true, 
    "jsx": "react", 
    "lib": ["es6"], 
    "moduleResolution": "node", 
    "noEmit": true, 
    "strict": true, 
    "target": "esnext", 
    "baseUrl": "./src", 
    "paths": { 
      "~/*": ["*"] 
    } 
  }, 
  "exclude": [ 
    "node_modules", 
    "babel.config.js", 
    "metro.config.js", 
    "jest.config.js" 
  ] 
} 


4. 컴포넌트 추가 절대경로 방식 : babel.config.js 수정

더보기
module.exports = { 
  presets: ['module:metro-react-native-babel-preset'], 
  plugins: [ 
    [ 
      'babel-plugin-root-import', 
      { 
        rootPathPrefix: '~', 
        rootPathSuffix: 'src', 
      }, 
    ], 
  ], 
}; 


5. js 소스코드 통합관리

1). src 폴더 생성 후 

2). App.js 파일을 App.tsx로 이름을 변경하여 src 폴더로 이동시킨다.
3). 타입스크립트 Styled 컴포넌트를 사용해서 ./src/App.tsx 파일을 수정

 

더보기
import React, {Fragment} from 'react';
import {StatusBar, SafeAreaView} from 'react-native';
import {
  Header,
  LearnMoreLinks,
  Colors,
  DebugInstructions,
  ReloadInstructions,
} from 'react-native/Libraries/NewAppScreen';
import Styled from 'styled-components/native';
const ScrollView = Styled.ScrollView`
 background-color: ${Colors.lighter};
`;
const Body = Styled.View`
 background-color: ${Colors.white};
`;
const SectionContainer = Styled.View`
 margin-top: 32px;
 padding-horizontal: 24px;
`;
const SectionDescription = Styled.Text`
 margin-top: 8px;
 font-size: 18px;
 font-weight: 400;
 color: ${Colors.dark};
`;
const HighLight = Styled.Text`
 font-weight: 700;
`;
interface Props {}
const App = ({}: Props) => {
  return (
    <Fragment>
      <StatusBar barStyle="dark-content" />
      <SafeAreaView>
        <ScrollView contentInsetAdjustmentBehavior="automatic">
          <Header />
          <Body>
            <SectionContainer>
              <SectionDescription>Step One</SectionDescription>
              <SectionDescription>
                Edit <HighLight>App.js</HighLight> to change this screen and
                then come back to see your edits.
              </SectionDescription>
            </SectionContainer>
            <SectionContainer>
              <SectionDescription>See Your Changes</SectionDescription>
              <SectionDescription>
                <ReloadInstructions />
              </SectionDescription>
            </SectionContainer>
            <SectionContainer>
              <SectionDescription>Debug</SectionDescription>
              <SectionDescription>
                <DebugInstructions />
              </SectionDescription>
            </SectionContainer>
            <SectionContainer>
              <SectionDescription>Learn More</SectionDescription>
              <SectionDescription>
                Read the docs to discover what to do next:
              </SectionDescription>
            </SectionContainer>
            <LearnMoreLinks />
          </Body>
        </ScrollView>
      </SafeAreaView>
    </Fragment>
  );
};
export default App;

 


6. 인덱스 수정

index.js

 

... 
import App from '~/App'; 
...

 

 


7.  AsyncStorage 설치 및 설정

npm install --save @react-native-community/async-storage

반응형

'React Native > React Native 일정관리 앱' 카테고리의 다른 글

[RN 3-4 프로젝트 개발 3]  (0) 2020.02.22
[RN 3-3 프로젝트 개발 2]  (0) 2020.02.22
[RN 3-2 프로젝트 개발 1]  (0) 2020.02.21