まあ、あなたは、それ自体、送信に関連するすべてをシーン自体に保存することによってそれを行うことができます。
どのようにですか?
オンデマンドでnavbarにボタンを挿入することで行います。
ここで私は私が働いているプロジェクトのために作成したソリューションです: https://rnplay.org/apps/dS31zw
アイデアはラベルと機能(と何でもあなたが好きを持つオブジェクトでナビゲーションバーのルートを提供することです..例えば、アイコン)
ボーナスとして、あなたもタイトルを挿入することができます!
注:このトリックは、NavigationBarRouteMapperが機能する前に呼び出されるcomponentWillMount()に依存します。これが将来的に変わるなら、間違いなくそれを破るでしょう。しかし、それは今完璧に動作します!
'use strict';
import React, {Component} from 'react';
import ReactNative from 'react-native';
const {
AppRegistry,
StyleSheet,
Text,
View,
Navigator,
Alert,
TouchableHighlight
} = ReactNative;
class Home extends Component {
//This trick depends on that componentWillMount fires before the navbar is created
componentWillMount() {
this.props.route.navbarTitle = "Home";
this.props.route.rightNavButton = {
text: "Button",
onPress: this._doSomething.bind(this)
};
}
_doSomething() {
Alert.alert(
'Awesome, eh?',
null,
[
{text: 'Indeed'},
]
)
}
render() {
return (
<View style={styles.container}>
<Text>You are home</Text>
</View>
);
}
}
class AppContainer extends Component {
renderScene(route, navigator) {
switch(route.name) {
case "Home":
//You must pass route as a prop for this trick to work properly
return <Home route={route} navigator={navigator} {...route.passProps} />
default:
return (
<Text route={route}
style={styles.container}>
Your route name is probably incorrect {JSON.stringify(route)}
</Text>
);
}
}
render() {
return (
<Navigator
navigationBar={
<Navigator.NavigationBar
style={ styles.navbar }
routeMapper={ NavigationBarRouteMapper } />
}
initialRoute={{ name: 'Home' }}
renderScene={ this.renderScene }
/>
);
}
}
//Nothing fancy here, except for checking for injected buttons.
var NavigationBarRouteMapper = {
LeftButton(route, navigator, index, navState) {
if(route.leftNavButton) {
return (
<TouchableHighlight
style={styles.leftNavButton}
underlayColor="transparent"
onPress={route.leftNavButton.onPress}>
<Text style={styles.navbarButtonText}>{route.leftNavButton.text}</Text>
</TouchableHighlight>
);
}
else if(route.enableBackButton) {
return (
<TouchableHighlight
style={styles.leftNavButton}
underlayColor="transparent"
onPress={() => navigator.pop() }>
<Text style={styles.navbarButtonText}>Back</Text>
</TouchableHighlight>
);
}
},
RightButton(route, navigator, index, navState) {
if(route.rightNavButton) {
return (
<TouchableHighlight
style={styles.rightNavButton}
underlayColor="transparent"
onPress={route.rightNavButton.onPress}>
<Text style={styles.navbarButtonText}>{route.rightNavButton.text}</Text>
</TouchableHighlight>
);
}
},
Title(route, navigator, index, navState) {
return (<Text style={styles.navbarTitle}>{route.navbarTitle || route.name}</Text>);
}
};
var styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
marginTop: 66
},
navbar: {
backgroundColor: '#ffffff',
},
navbarTitle: {
marginVertical: 10,
fontSize: 17
},
leftNavButton: {
marginVertical: 10,
paddingLeft: 8,
},
rightNavButton: {
marginVertical: 10,
paddingRight: 8,
},
navbarButtonText: {
fontSize: 17,
color: "#007AFF"
}
});
AppRegistry.registerComponent('AppContainer',() => AppContainer);
ニースの解決策!ちょうどこれで苦労している。ヒントありがとう! 初期ボタンをどのように割り当てますか?シーンごとにボタンを挿入しますが、ルートから「メニュー」ボタンを割り当てたいと思います。 – funkysoul
@funkysoulzh NavigationBarRouteMapper内の適切なメソッド、たとえばLeftButtonで、if-condition節を追加し、その中にボタンを追加します。 LeftButtonメソッドに戻るボタンを追加する方法と同じです。しかし、あなたの場合は、ルート名を確認したいかもしれません。 –
こんにちはアーメド、私は自分のロジックが曲がっていることに気付きました。私は初期のシーンから始めて、そのシーンに「初期」ボタンを付けることもできます。 あなたが何かの前に座ると、あなたは突然、それがどれほど簡単か分かりません;-)。とにかく上記のおかげで! – funkysoul