05 ReactNavigation入門詳解(參照官網(wǎng)文檔)(下)

頭部按鈕

  1. 通過headerLeft和headerRight來添加左右按鈕
class HomeScreen extends React.Component {
  static navigationOptions = ({navigation})=>{
    return {
    // title: 'Home',
    headerTitle:<LogoTitle/>,
    // 同時(shí)添加左右鍵 保證居中
    headerLeft:(
      <Button onPress={()=>navigation.goBack()}
      title ="Back"
      color = "#000"   />
    ),
    // 添加一個(gè)右鍵
    headerRight:(
      <Button onPress={()=> alert('just test')}
      title ="info"
      color = "#839"  
      />
    ),
......下略

在navigationOptions,this指向的不是HomeScreen幸撕,所以不能用this來調(diào)用。
用自定義的按鈕連接goBack方法援所,可以處理默認(rèn)返回鍵返回很慢的問題外莲。

  1. js中的 || 運(yùn)算
    前面看到一個(gè)獲取參數(shù)的例子是這樣的
  // 函數(shù)傳入一個(gè)navigation,獲取state降铸,設(shè)置title
  static navigationOptions = ({navigation,navigationOptions}) =>{
    const {params} = navigation.state;
    return {
      title:params?params.msg:'A Details Screen',
    }
  };

在將頭部按鈕時(shí)在旱,官方又給了一個(gè)這樣的例子

const params = navigation.state.params || {};

查了下,js中表示垮耳,navigation.state.params不為空則賦值颈渊,否則使用后面的值賦值。和java的短路或不太一樣终佛。
RN不能保證你的screen組件的掛載會(huì)優(yōu)先于你的header俊嗽,所以params可能為{};
可以通過Redux或者M(jìn)obx來實(shí)現(xiàn)header和screen的交互

  1. 自定義返回按鈕

headerBackTitle IOS 有效
headerTruncatedBackTitle 似乎安卓無效
headerBackImage 注意背景色不要覆蓋,否則只能看到色塊 铃彰。
通過設(shè)置headerLeft可以覆蓋默認(rèn)返回按鈕

Opening a full-screen modal(全屏模態(tài)展示)

  1. modal
    A modal displays content that temporarily blocks interactions with the main view(臨時(shí)地阻止與主屏幕的交互绍豁,這種展示形式成為模態(tài)展示)

  2. 建立一個(gè)模態(tài)頁面

class HomeScreen extends React.Component {
  static navigationOptions = ({ navigation }) => {
    const params = navigation.state.params || {};

    return {
      headerLeft: (
        <Button
          onPress={() => navigation.navigate('MyModal')}
          title="Info"
          color="#fff"
        />
      ),
      /* the rest of this config is unchanged */
    };
  };

  /* render function, etc */
}

class ModalScreen extends React.Component {
  render() {
    return (
      <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
        <Text style={{ fontSize: 30 }}>This is a modal!</Text>
        <Button
          onPress={() => this.props.navigation.goBack()}
          title="Dismiss"
        />
      </View>
    );
  }
}

const MainStack = StackNavigator(
  {
    Home: {
      screen: HomeScreen,
    },
    Details: {
      screen: DetailsScreen,
    },
  },
  {
    /* Same configuration as before */
  }
);

const RootStack = StackNavigator(
  {
    Main: {
      screen: MainStack,// 這個(gè)有導(dǎo)航欄
    },
    MyModal: {
      screen: ModalScreen, // 這個(gè)沒有導(dǎo)航欄
    },
  },
  {
    mode: 'modal',
    headerMode: 'none',// 設(shè)置模式 不加Main會(huì)有兩個(gè)導(dǎo)航欄
  }
);

這里實(shí)現(xiàn)了兩個(gè)StackNavigator的嵌套,一個(gè)棧是有導(dǎo)航欄的牙捉,一個(gè)棧是沒有的竹揍。
模式配置可以是card或者modal敬飒,這個(gè)對(duì)安卓沒有影響,只影響ios上的轉(zhuǎn)換效果(modal時(shí)從下到上芬位,card是從右到左)
在導(dǎo)航時(shí)不需要指定所在的棧无拗,只需要指定頁面名稱。官方提供了這樣一張圖昧碉。從HOME導(dǎo)航到modal英染,如果mainstack不能處理,會(huì)交給rootstack來處理被饿。

tree.png

其他

  1. StackNavigator不能實(shí)現(xiàn)圖表式的切換四康,需要使用TabNavigator。這里先不提狭握,參見TabNavigator
  2. 想要了解內(nèi)部機(jī)理參見Build your own Navigator
  3. 其他API參見API Reference

全部代碼

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末闪金,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子论颅,更是在濱河造成了極大的恐慌哎垦,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件嗅辣,死亡現(xiàn)場(chǎng)離奇詭異撼泛,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)澡谭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門愿题,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蛙奖,你說我怎么就攤上這事潘酗。” “怎么了雁仲?”我有些...
    開封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵仔夺,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我攒砖,道長(zhǎng)缸兔,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任吹艇,我火速辦了婚禮惰蜜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘受神。我一直安慰自己抛猖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著财著,像睡著了一般联四。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上撑教,一...
    開封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天朝墩,我揣著相機(jī)與錄音,去河邊找鬼驮履。 笑死鱼辙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的玫镐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼怠噪,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼恐似!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起傍念,我...
    開封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤矫夷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后憋槐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體双藕,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年阳仔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了忧陪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡近范,死狀恐怖嘶摊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情评矩,我是刑警寧澤叶堆,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站斥杜,受9級(jí)特大地震影響虱颗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蔗喂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一忘渔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧弱恒,春花似錦辨萍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽爪飘。三九已至,卻和暖如春拉背,著一層夾襖步出監(jiān)牢的瞬間师崎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工椅棺, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留犁罩,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓两疚,卻偏偏與公主長(zhǎng)得像床估,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子诱渤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容