React Native-라우터

이 장에서는 React Native의 탐색을 이해합니다.

1 단계 : 라우터 설치

우선, 우리는 Router. 이 장에서는 React Native Router Flux를 사용합니다. 프로젝트 폴더의 터미널에서 다음 명령을 실행할 수 있습니다.

npm i react-native-router-flux --save

2 단계 : 전체 신청서

라우터가 전체 애플리케이션을 처리하기를 원하므로이를 추가합니다. index.ios.js. Android의 경우 다음에서 동일한 작업을 수행 할 수 있습니다.index.android.js.

App.js

import React, { Component } from 'react';
import { AppRegistry, View } from 'react-native';
import Routes from './Routes.js'

class reactTutorialApp extends Component {
   render() {
      return (
         <Routes />
      )
   }
}
export default reactTutorialApp
AppRegistry.registerComponent('reactTutorialApp', () => reactTutorialApp)

3 단계 : 라우터 추가

이제 우리는 Routes구성 요소 폴더 내의 구성 요소. 돌아올 것이다Router여러 장면으로. 각 장면에는key, componenttitle. 라우터는 키 속성을 사용하여 장면 사이를 전환하고 구성 요소가 화면에 렌더링되고 제목이 탐색 모음에 표시됩니다. 우리는 또한 설정할 수 있습니다initial 속성을 처음에 렌더링 할 장면에 추가합니다.

Routes.js

import React from 'react'
import { Router, Scene } from 'react-native-router-flux'
import Home from './Home.js'
import About from './About.js'

const Routes = () => (
   <Router>
      <Scene key = "root">
         <Scene key = "home" component = {Home} title = "Home" initial = {true} />
         <Scene key = "about" component = {About} title = "About" />
      </Scene>
   </Router>
)
export default Routes

4 단계 : 구성 요소 만들기

우리는 이미 Home이전 장의 구성 요소; 이제 우리는About구성 요소. 우리는goToAbout 그리고 goToHome 장면 사이를 전환하는 기능.

Home.js

import React from 'react'
import { TouchableOpacity, Text } from 'react-native';
import { Actions } from 'react-native-router-flux';

const Home = () => {
   const goToAbout = () => {
      Actions.about()
   }
   return (
      <TouchableOpacity style = {{ margin: 128 }} onPress = {goToAbout}>
         <Text>This is HOME!</Text>
      </TouchableOpacity>
   )
}
export default Home

About.js

import React from 'react'
import { TouchableOpacity, Text } from 'react-native'
import { Actions } from 'react-native-router-flux'

const About = () => {
   const goToHome = () => {
      Actions.home()
   }
   return (
      <TouchableOpacity style = {{ margin: 128 }} onPress = {goToHome}>
         <Text>This is ABOUT</Text>
      </TouchableOpacity>
   )
}
export default About

앱은 이니셜을 렌더링합니다. Home 화면.

버튼을 눌러 정보 화면으로 전환 할 수 있습니다. 뒤로 화살표가 나타납니다. 이를 사용하여 이전 화면으로 돌아갈 수 있습니다.