화면 구성하기 


 본격적으로 App을 만들기 위해서 구성한 화면이다. Timer App을 아래와 같이 만들어봤다. 

 

Timer 상위 카테고리 
Timer 하위 카테고리 

위의 화면을 구성하기 위해서 React Native에서 기본적으로 배워야할 Layout 구성 방식을 보면, 

 

1. Layout with FlexBox 

 

  Flex는  내가 지정할 View를 지정가능한 공간에 대해서 얼마나 "채울수" 있는지 지정할 수 있다. 즉 비율로 상대적 크기를 설정할 수 있다. 

 

  Flex 값은 각각의 영역을 구분하는데 효과적으로 사용할 수 있는데,

 

  예를 들어 

 

    <View style={{flex : 1}} >

         <View style={{flex : 2}}></View>

         <View style={{flex : 3}}></View>

    </View>

 

   와 같은 레이아웃으로 구성되어 있다고 할 때, 

 

  가장 외부를 감싸고 있는 View의 높이를 기준으로 내부의 View는 각각 2/5 , 3/5의 높이를 가지게 된다. 

 

import React, { Component} from 'react';
import {
  View,
} from 'react-native';



class App extends Component {
  render(){
    return (
      <View style={{flex : 1, backgroundColor:"white"}} >
  
           <View style={{flex : 2, backgroundColor:"red"}}></View>
  
           <View style={{flex : 3, backgroundColor:'blue'}}></View>
  
      </View>
    );
  }
};

export default App;

위의 코드를 실제로 실행해보면 아래와 같이 영역이 구분되는 것을 볼 수 있다.      

2/5 , 3/5

여기에서 부모의 View를 크기 내에서 자식들의 View의 영역을 비율로 지정하는 것인데, 실제로 부모의 View의 크기를 조정하면 아래와 같이 조정할 수 있다. 

import React, { Component} from 'react';
import { View, } from 'react-native';

class App extends Component {
  render(){
    return (
      <View style={{ height:400, backgroundColor:"white" }} >
           <View style={{flex : 2, backgroundColor:"red"}}></View>
           <View style={{flex : 3, backgroundColor:'blue'}}></View>
      </View>
    );
  }
};

export default App;

강제로 View의 높이를 400으로 지정했을 때 내부의 View의 크기가 "상대적"으로 각각의 비율(2/5 , 3/5)에 따라 조정되었다. 

 

2. Flex Direction

 

 flexDirection은 각각의 하위 아이템들의 정렬 방향을 지정할 수 있다. 

 

   flexDirection : 'row' 로 지정되면, 행을 기준으로 정렬된다. 

 

<View style={{ flex :1, flexDirection : 'row', backgroundColor:"white" }} >
   <View style={{flex : 2, height : 60, backgroundColor:"red"}}></View>
   <View style={{flex : 3, height : 60, backgroundColor:'blue'}}></View>
 </View>

   

flexDirection : 'row'

    flexDirection : 'row-reverse' 로 지정되면 내부 아이템의 정렬이 반대로 적용된다. 

 

<View style={{ flex :1, flexDirection : 'row-reverse', backgroundColor:"white" }} >
           <View style={{flex : 2, height : 60, backgroundColor:"red"}}></View>
           <View style={{flex : 3, height : 60, backgroundColor:'blue'}}></View>
      </View>

row-direction : 'row-reverse'

     flexDirection : 'column' 으로 지정되면 내부 아이템이 세로로 위치된다.

 

class App extends Component {
  render(){
    return (
      <View style={{ flex :1, flexDirection : "column", backgroundColor:"white", marginTop : 100, backgroundColor : '#00ffff' }} >
           <View style={{height : 60, width : 60, backgroundColor:"red"}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'blue'}}></View>
      </View>
    );
  }
};

flexDirection : 'column'

     flexDirection : 'column-reverse' 으로 지정되면 아이템의 정렬 순서 및 시작위치가 반대로 위치한다.

class App extends Component {
  render(){
    return (
      <View style={{ flex :1, flexDirection : "column-reverse", backgroundColor:"white", marginTop : 100, marginBottom :100, backgroundColor : '#00ffff' }} >
           <View style={{height : 60, width : 60, backgroundColor:"red"}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'blue'}}></View>
      </View>
    );
  }
};

flexDirection : 'column-reverse'

3. Layout Direction

 

  Justity Content - 내부 아이템을 감싸는 Container를 기준으로 어떻게 정렬할 것인지를 지정할 수 있음 

import React, { Component} from 'react';
import { View, } from 'react-native';

class App extends Component {
  render(){
    return (
      <View style={{ flex :1, flexDirection : "column-reverse", justifyContent : 'space-around' , backgroundColor:"white", marginTop : 100, marginBottom :100, backgroundColor : '#00ffff' }} >
           <View style={{height : 60, width : 60, backgroundColor:"red"}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'blue'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'yellow'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'green'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'purple'}}></View>
      </View>
    );
  }
};

export default App;

     

  Align Items - 내부 아이템을 감싸는 Continer의 가로축을 기준으로 어떻게 정렬할 것인지를 지정할 수 있음 

import React, { Component} from 'react';
import { View, } from 'react-native';

class App extends Component {
  render(){
    return (
      <View style={{ flex :1, flexDirection : "column-reverse", alignItems : 'center', backgroundColor:"white", marginTop : 100, marginBottom :100, backgroundColor : '#00ffff' }} >
           <View style={{height : 60, width : 60, alignSelf : 'flex-start', backgroundColor:"red"}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'blue'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'yellow'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'green'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'purple'}}></View>
      </View>
    );
  }
};

export default App;

  Align Self  - 내부 아이템 각각의 정렬 어떻게 정렬할 지를 지정할 수 있고 만약 부모 Container에서 Align Item이 선언되어 있다면 해당 속성은 AlignSelf에 의해 무시된다. 

import React, { Component} from 'react';
import { View, } from 'react-native';

class App extends Component {
  render(){
    return (
      <View style={{ flex :1, flexDirection : "column-reverse", alignItems : 'center', backgroundColor:"white", marginTop : 100, marginBottom :100, backgroundColor : '#00ffff' }} >
           <View style={{height : 60, width : 60, alignSelf : 'flex-start', backgroundColor:"red"}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'blue'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'yellow'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'green'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'purple'}}></View>
      </View>
    );
  }
};

export default App;

  Align Content - 횡축을 기준으로 분포를 정의하는데, 이는 flexWrap을 사용하는 다중 라인(줄)으로 감쌀때만 적용된다. 

import React, { Component} from 'react';
import { View, } from 'react-native';

class App extends Component {
  render(){
    return (
      <View style={{ flex :1, flexDirection : "column-reverse", flexWrap : 'wrap', alignContent : 'center', backgroundColor:"white", marginTop : 100, marginBottom :100, backgroundColor : '#00ffff' }} >
           <View style={{height : 60, width : 60, backgroundColor:"red"}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'blue'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'yellow'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'green'}}></View>
           <View style={{height : 60, width : 60, backgroundColor:'purple'}}></View>
      </View>
    );
  }
};

export default App;

 Flex Wrap - 내부의 아이템의 Container의 사이즈를 벗어나는 것을 제어하고자 할 때 사용할 수 있다. alignContent는 아이템에 Container 영역을 넘어서서 다음칸으로 채워질 때 어떤 정렬로 채워지게 할 것인가를 정할 수 있다. 

 

 그외에도 

 

 flexGrow, flexShrink, flexBasis 등의 옵션이 존재한다. 

 

 

 

'따라해보기' 카테고리의 다른 글

0001 React Native App 개발기 6-1  (0) 2019.12.12
0001 React Native App 개발기 5  (0) 2019.12.08
0001 React Native App 개발기 3  (1) 2019.11.17
0001 React Native App 개발기 2  (0) 2019.11.15
0001 React Native App 개발기 1  (0) 2019.11.15

+ Recent posts