createStackNavigator
createStackNavigator
提供APP屏幕之間切換的能力俱诸,它是以棧的形式還管理屏幕之間的切換,新切換到的屏幕會(huì)放在棧的頂部旷偿。
屏幕轉(zhuǎn)場風(fēng)格
默認(rèn)情況下,createStackNavigator提供了轉(zhuǎn)場過渡效果壁酬,在Android和iOS上過渡效果是不同的邓嘹,這也是React Native重平臺(tái)性的一個(gè)體現(xiàn),在Android上從屏幕底部淡入擅笔,在iOS上是從屏幕的右側(cè)劃入志衣,當(dāng)然你也可以通過配置讓StackNavigator支持屏幕從底部滑入的效果。
createStackNavigator API
createStackNavigator(RouteConfigs, StackNavigatorConfig):
-
RouteConfigs
(必選):路由配置對(duì)象是從路由名稱到路由配置的映射猛们,告訴導(dǎo)航器該路由呈現(xiàn)什么念脯。 -
StackNavigatorConfig
(可選):配置導(dǎo)航器的路由(如:默認(rèn)首屏,navigationOptions弯淘,paths等)樣式(如绿店,轉(zhuǎn)場模式mode、頭部模式等)耳胎。
從createStackNavigator API上可以看出createStackNavigator
支持通過RouteConfigs
和 StackNavigatorConfig
兩個(gè)參數(shù)來創(chuàng)建createStackNavigator導(dǎo)航器惯吕。
RouteConfigs
RouteConfigs支持三個(gè)參數(shù)screen
废登、path
以及navigationOptions
;
-
screen
(必選):指定一個(gè) React 組件作為屏幕的主要顯示內(nèi)容郁惜,當(dāng)這個(gè)組件被createStackNavigator加載時(shí)堡距,它會(huì)被分配一個(gè)navigation
prop。 -
path
(可選):用來設(shè)置支持schema跳轉(zhuǎn)時(shí)使用兆蕉,具體使用會(huì)在下文的有關(guān)Schema
章節(jié)中講到羽戒; -
navigationOptions
(可選):用以配置全局的屏幕導(dǎo)航選項(xiàng)如:title、headerRight虎韵、headerLeft等易稠;
StackNavigatorConfig
從react-navigation
源碼中可以看出StackNavigatorConfig支持配置的參數(shù)有10個(gè)。
function createStackNavigator(routeConfigMap, stackConfig = {}) {
const {
initialRouteKey,
initialRouteName,
initialRouteParams,
paths,
navigationOptions,
disableKeyboardHandling,
getCustomActionCreators
} = stackConfig;
...
這7個(gè)參數(shù)可以根據(jù)作用不同分為路由配置包蓝、視圖樣式配置兩類驶社,首先看用于路由配置的參數(shù):
用于路由配置的參數(shù):
- initialRouteName: 設(shè)置默認(rèn)的頁面組件企量,必須是上面已注冊(cè)的頁面組件。
- initialRouteParams: 初始路由的參數(shù)亡电。
- navigationOptions: 屏幕導(dǎo)航的默認(rèn)選項(xiàng)届巩,下文會(huì)詳細(xì)講解。
- initialRouteKey - 初始路由的可選標(biāo)識(shí)符份乒。
- paths: 用來設(shè)置支持schema跳轉(zhuǎn)時(shí)使用恕汇,具體使用會(huì)在下文的有關(guān)
Schema
章節(jié)中講到。
用于導(dǎo)航樣式配置的參數(shù):
- mode: 頁面切換模式: 左右是card(相當(dāng)于iOS中的push效果), 上下是modal(相當(dāng)于iOS中的modal效果)
- card: 普通app常用的左右切換。
- modal: 上下切換孝凌。
- headerMode: 導(dǎo)航欄的顯示模式: screen: 有漸變透明效果, float: 無透明效果, none: 隱藏導(dǎo)航欄方咆。
- float: 無透明效果, 默認(rèn)。
- screen: 有漸變透明效果, 如微信QQ的一樣蟀架。
- none: 隱藏導(dǎo)航欄瓣赂。
- headerBackTitleVisible : 提供合理的默認(rèn)值以確定后退按鈕標(biāo)題是否可見,但如果要覆蓋它片拍,則可以使用true或` false 在此選項(xiàng)中煌集。
- fade-in-place: 標(biāo)題組件交叉淡入淡出而不移動(dòng),類似于iOS的Twitter捌省,Instagram和Facebook應(yīng)用程序苫纤。 這是默認(rèn)值。
- uikit: iOS的默認(rèn)行為的近似值纲缓。
headerTransitionPreset: 指定在啟用headerMode:float時(shí)header應(yīng)如何從一個(gè)屏幕轉(zhuǎn)換到另一個(gè)屏幕卷拘。
- cardStyle: 樣式(iOS上頁面切換會(huì)有白色漸變蒙層,想去掉則可以這樣設(shè)置祝高,cardStyle: { opacity: null },切換頁面時(shí)的頁面邊框也在這里可以設(shè)置)栗弟。
- onTransitionStart: 頁面切換開始時(shí)的回調(diào)函數(shù) (我們可以在這里注冊(cè)一些通知,告知我們切面切換的狀態(tài)工闺,方便后面處理頁面切換事件)乍赫。
- onTransitionEnd: 頁面切換結(jié)束時(shí)的回調(diào)函數(shù)。
navigationOptions(屏幕導(dǎo)航選項(xiàng))
支持一下參數(shù):
- title: 可以作為headerTitle的備選字段(當(dāng)沒設(shè)置headerTitle時(shí)會(huì)用該字段作為標(biāo)題)陆蟆,也可以作為TabNavigator的tabBarLabel以及DrawerNavigator的drawerLabel雷厂。
- header: 自定義導(dǎo)航條,可以通過設(shè)置null來隱藏導(dǎo)航條叠殷;
- headerTitle: 標(biāo)題改鲫;
- headerTitleAllowFontScaling: 標(biāo)題是否允許縮放,默認(rèn)true;
- headerBackTitle: 定義在iOS上當(dāng)前頁面進(jìn)入到下一頁面的回退標(biāo)題钩杰,可以通過設(shè)置null來禁用它纫塌;
- headerTruncatedBackTitle: 當(dāng)回退標(biāo)題不能顯示的時(shí)候顯示此屬性的標(biāo)題,比如回退標(biāo)題太長了讲弄;
- headerBackImage:React 元素或組件在標(biāo)題的后退按鈕中顯示自定義圖片。 當(dāng)組件被調(diào)用時(shí)依痊,它會(huì)在渲染時(shí)收到許多 props 如:(tintColor避除,title)。 默認(rèn)為帶有 react-navigation/views/assets/back-icon.png 這張圖片的組件胸嘁,后者是平臺(tái)的默認(rèn)后圖標(biāo)圖像(iOS上為向左的符號(hào)瓶摆,Android上為箭頭)。
- headerRight: 定義導(dǎo)航欄右邊視圖性宏;
- headerLeft: 定義導(dǎo)航欄左邊視圖群井;
- headerStyle: 定義導(dǎo)航欄的樣式,比如背景色等毫胜;
- headerTitleStyle: 定義標(biāo)題的樣式书斜;
- headerLeftContainerStyle:自定義 headerLeft 組件容器的樣式,例如酵使,增加 padding荐吉。
- headerRightContainerStyle:自定義 headerRight 組件容器的樣式,,例如口渔,增加 padding样屠。
- headerTitleContainerStyle:自定義 headerTitle 組件容器的樣式, 例如,增加 padding缺脉。
- headerBackTitleStyle: 定義返回標(biāo)題的樣式痪欲;
- headerPressColorAndroid:顏色為材料波紋 (Android >= 5.0);
- headerTintColor: 定義導(dǎo)航條的tintColor攻礼,會(huì)覆蓋headerTitleStyle中的顏色业踢;
- headerTransparent:默認(rèn)為 false。如果 true, 則標(biāo)頭將不會(huì)有背景, 除非您顯式提供 headerStyle 或 headerBackground秘蛔。
- headerBackground:與headerTransparent一起使用陨亡,以提供在標(biāo)題后臺(tái)呈現(xiàn)的組件。 例如深员,您可以使用模糊視圖來創(chuàng)建半透明標(biāo)題负蠕。
- gesturesEnabled: 定義是否能側(cè)滑返回,iOS默認(rèn)true倦畅,Android默認(rèn)false遮糖;
- gestureResponseDistance: 定義滑動(dòng)返回的有效距離,水平狀態(tài)下默認(rèn):25叠赐,垂直狀態(tài)默認(rèn)135欲账;
- gestureDirection: 設(shè)置關(guān)閉手勢的方向屡江。默認(rèn)從左向右,可以設(shè)置從右到左的滑動(dòng)操作赛不。
【案例】使用StackNavigator做界面導(dǎo)航惩嘉、配置navigationOptions
第一步:創(chuàng)建一個(gè)StackNavigator類型的導(dǎo)航器
export const AppStackNavigator = createStackNavigator({
HomePage: {
screen: HomePage
},
Page1: {
screen: Page1,
navigationOptions: ({navigation}) => ({
title: `${navigation.state.params.name}頁面名`//動(dòng)態(tài)設(shè)置navigationOptions
})
},
Page2: {
screen: Page2,
navigationOptions: {//在這里定義每個(gè)頁面的導(dǎo)航屬性,靜態(tài)配置
title: "This is Page2.",
}
},
Page3: {
screen: Page3,
navigationOptions: (props) => {//在這里定義每個(gè)頁面的導(dǎo)航屬性踢故,動(dòng)態(tài)配置
const {navigation} = props;
const {state, setParams} = navigation;
const {params} = state;
return {
title: params.title ? params.title : 'This is Page3',
headerRight: (
<Button
title={params.mode === 'edit' ? '保存' : '編輯'}
onPress={() =>
setParams({mode: params.mode === 'edit' ? '' : 'edit'})}
/>
),
}
}
},
}, {
defaultNavigationOptions: {
// header: null,// 可以通過將header設(shè)為null 來禁用StackNavigator的Navigation Bar
}
});
第二步:配置navigationOptions:
步驟一的代碼中通過兩種方式配值了navigationOptions:
靜態(tài)配置:
對(duì)Page2的navigationOptions配置是通過靜態(tài)配置完成的:
Page2: {
screen: Page2,
navigationOptions: {//在這里定義每個(gè)頁面的導(dǎo)航屬性殿较,靜態(tài)配置
title: "This is Page2.",
}
},
這種方式被稱為靜態(tài)配置耸峭,因?yàn)閚avigationOptions中的參數(shù)是直接Hard Code的不依賴于變量。
動(dòng)態(tài)配置:
對(duì)Page3的navigationOptions配置是通過動(dòng)態(tài)配置完成的:
Page3: {
screen: Page3,
navigationOptions: (props) => {//在這里定義每個(gè)頁面的導(dǎo)航屬性淋纲,動(dòng)態(tài)配置
const {navigation} = props;
const {state, setParams} = navigation;
const {params} = state;
return {
title: params.title ? params.title : 'This is Page3',
headerRight: (
<Button
title={params.mode === 'edit' ? '保存' : '編輯'}
onPress={() =>
setParams({mode: params.mode === 'edit' ? '' : 'edit'})}
/>
),
}
}
},
從上述代碼中可以看出Page3的navigationOptions依賴于props這個(gè)變量所以是動(dòng)態(tài)的劳闹,當(dāng)props中的內(nèi)容發(fā)生變化時(shí),navigationOptions也會(huì)跟著變化洽瞬;
提示:除了在創(chuàng)建createStackNavigator時(shí)配置navigationOptions外本涕,在StackNavigator之外也可以配置navigationOptions;
createStackNavigator之外也可以配置navigationOptions
方式一:
Page2.navigationOptions = {
title: "This is Page2.",
};
方式二:
export default class Page1 extends React.Component {
//也可在這里定義每個(gè)頁面的導(dǎo)航屬性片任,這里的定義會(huì)覆蓋掉別處的定義
static navigationOptions = {
title: 'Page1',
};
...
第三步:界面跳轉(zhuǎn)
export default class HomePage extends React.Component {
//在這里定義每個(gè)頁面的導(dǎo)航屬性
static navigationOptions = {
title: 'Home',
headerBackTitle:'返回哈哈',//設(shè)置返回此頁面的返回按鈕文案对供,有長度限制
}
render() {
const {navigation} = this.props;
return <View style={{flex: 1, backgroundColor: "orange",}}>
<Text style={styles.text}>歡迎來到HomePage</Text>
<Button
title="Go To Page1"
onPress={() => {
navigation.navigate('Page1', {name: '動(dòng)態(tài)的'});
}}
/>
<Button
title="Go To Page2"
onPress={() => {
navigation.navigate('Page2');
}}
/>
<Button
title="Go To Page3"
onPress={() => {
navigation.navigate('Page3',{ name: 'Devio' });
}}
/>
</View>
}
}
代碼解析:
頁面跳轉(zhuǎn)可分為兩步:
-
- 獲取navigation:
const {navigation} = this.props;
-
- 通過
navigate(routeName, params, action)
進(jìn)行頁面跳轉(zhuǎn):
navigation.navigate('Page2'); navigation.navigate('Page3',{ name: 'Devio' });
這里在跳轉(zhuǎn)到
Page3
的時(shí)候傳遞了參數(shù){ name: 'Devio' }
位他; - 通過
第四步:更新頁面Params與返回
export default class Page3 extends React.Component {
render() {
const {navigation} = this.props;
const {state, setParams} = navigation;
const {params} = state;
const showText = params.mode === 'edit' ? '正在編輯' : '編輯完成';
return <View style={{flex: 1, backgroundColor: "gray",}}>
<Text style={styles.text}>歡迎來到Page3</Text>
<Text style={styles.showText}>{showText}</Text>
<TextInput
style={styles.input}
onChangeText={text=>{
setParams({title:text})
}}
/>
<Button
title="Go Back"
onPress={() => {
navigation.goBack();
}}
/>
</View>
}
}
代碼解析:
在上述代碼中通過:
<TextInput
style={styles.input}
onChangeText={text=>{
setParams({title:text})
}}
/>
將輸入框中內(nèi)容的變化鹅髓,通過setParams({title:text})
更新到頁面的標(biāo)題上,你會(huì)看到當(dāng)輸入框中內(nèi)容發(fā)生變化時(shí)京景,標(biāo)題也會(huì)跟著變窿冯。
當(dāng)用戶單擊Go Back
按鈕時(shí),通過:
navigation.goBack();
實(shí)現(xiàn)了返回上一頁确徙;
類似上述的應(yīng)用場景有很多醒串,大家可以通過與本教程配套的最新版React Native+Redux打造高質(zhì)量上線App視頻教程進(jìn)行進(jìn)一步學(xué)習(xí)react-navigation的更多高級(jí)應(yīng)用。
- 大家在學(xué)習(xí)使用React Navigation3x過程中遇到任何問題都可以在React Navigation3x的視頻教程中尋找答案哈鄙皇。
- 另外芜赌,也可以通過最新版React Native+Redux打造高質(zhì)量上線App視頻教程學(xué)習(xí)React Navigation3x開發(fā)的更多實(shí)戰(zhàn)經(jīng)驗(yàn)和技巧,以及優(yōu)化思路伴逸。