웹페이지에서는 url을 통해 페이지를 이동한다.
때문에 url을 지정할 수 있는 Link 컴포넌트나 a태그를 통해 페이지간의 이동을 컨트롤 했다.
하지만 어플리케이션에는 url이 없다... 그래서 우리는 stack Navigation을 이용해야한다!
stackNavigation
data:image/s3,"s3://crabby-images/abfd3/abfd31e6e9a03322a21c88d9fd810d617514e239" alt=""
npm install react-navigation
- 서로 link를 시켜야되는 components를 createStackNavigator의 인자에 객체 형태로 넣어준다.
- createStackNavigator를 createAppContainer로 감싼 후, export!
components
data:image/s3,"s3://crabby-images/0e48d/0e48d690a1cb152b323d55148dc07e2361bf13fb" alt=""
props를 확인해보면 navigation이라는 녀석이 있다!
data:image/s3,"s3://crabby-images/e08f9/e08f918a5f003c24f67d1924401c8636c8871ed5" alt=""
특정 태그에서 다음 화면(stack)으로 이동할 경로를 설정하자
- 이벤트가 발생했을 때 화면을 이동하도록 위와 같이 경로를 설정한다.
- props로 받은 navigation의 navigate라는 메소드를 사용하여, 인자로 이동할 component의 이름을 넣어준다.
- 해당 component에서 props를 전달하고 싶다면, 두번째 인자를 객체 타입으로 설정하고 그 안에서 전달하고자하는 props를 입력한다.
data:image/s3,"s3://crabby-images/47a13/47a137bdc74588b9d68b3946a273444ab6852330" alt=""
data:image/s3,"s3://crabby-images/41e64/41e643e450dbf7bf253008d3e1ec32c8af3c42b1" alt=""
이동한 component에서 console.log를 실행해보자.
- props를 확인해보면 위와 같이 내가 지정한props와 navigation 객체가 출력되는 것을 확인 할 수 있다!
data:image/s3,"s3://crabby-images/d8578/d85780007b3d799ecb20ff9a69c1775b15680ee2" alt=""
- 마찬가지로 그보다 더 자식 component에 props를 전달하기 위해서는 지정을 다시 해주어야 한다.
data:image/s3,"s3://crabby-images/80348/8034842e814ae5c105875794debd10079112b18b" alt=""
console.log에 잘 나오는 것을 확인 할 수 있다! 😆
data:image/s3,"s3://crabby-images/10b9e/10b9e25d061a197d0b90cd504064e9bb18c530e5" alt=""
result
data:image/s3,"s3://crabby-images/1418b/1418beea489a0cad65272dc5eab44f5caae833ca" alt=""
혹시 해당 작업물
깃 주소 알려주실 수 있으실까요?