【React Native】ナビゲーションバーのデザインを変更する

React Navigation でアプリのページ遷移の管理を行っているのですが、ヘッダーのデザインを変更したいという要望があったのでその対処方法についてです。
ちなみに、思ったよりも簡単でした!

参考にした公式ページはこちら。

Configuring the header bar | React Navigation
https://reactnavigation.org/docs/headers/

 

実装方法ですが、<Stack.Navigator>screenOptionsheaderStyle を設定するだけです!
サンプルコードは下記のとおりです。

import { StyleSheet } from 'react-native';

const styles = StyleSheet.create({
  header: {
    borderBottomWidth: 3,
    borderBottomColor: 'blue',

  },
});
<Stack.Navigator
  initialRouteName='top'
  screenOptions={{ headerStyle: styles.header }}>
  <Stack.Screen name="top" component={TopPage} options={{ title: 'トップ' }} />
  ......
</Stack.Navigator>

上記のように設定したところ、ヘッダーの下部に高さ 3 の青い線が表示されました!
今回はそんなに複雑な処理をしていないので分かりませんが、他にも影を消したり、背景色を変更したりなど、StyleSheet で使えるものは大概適用されそうでした。

 

以上、React Native でナビゲーションバーのデザインを変更する方法でした。
ご参考になれば幸いです。

>株式会社シーポイントラボ

株式会社シーポイントラボ

TEL:053-543-9889
営業時間:9:00~18:00(月〜金)
住所:〒432-8003
   静岡県浜松市中央区和地山3-1-7
   浜松イノベーションキューブ 315
※ご来社の際はインターホンで「316」をお呼びください

CTR IMG