У меня есть встроенное приложение, где я использую навигатор по табуляциям с react-navigation
. Здесь я использую функцию для изменения состояния другого компонента навигатора вкладок для изменения языка с помощью AsyncStorage
. Вот код, где я выполняю функцию:
export class Settings extends Component {
constructor(props) {
super(props);
this.state = {
toggle: false
};
}
funcCallen = async () => {
try {
await AsyncStorage.setItem('toggle', JSON.stringify(false))
this.setState({ toggle: false})
} catch (e) {
console.log(e)
}
console.log('en:', this.state.toggle)
}
funcCallch = async () => {
try {
await AsyncStorage.setItem('toggle', JSON.stringify(true))
this.setState({ toggle: true})
} catch (e) {
console.log(e)
}
console.log('ch:', this.state.toggle)
}
render() {
return (
<Container>
<Header>
<Body style={{ marginLeft: 20 }}>
<Title >Settings</Title>
</Body>
</Header>
<Content>
<View style={{ flexDirection: 'row', paddingVertical: 20, paddingHorizontal: 20 }}>
<Icon name='lock' style={{ color: '#bde814', marginRight: 10 }} />
<Text style={{ fontSize: 20, fontWeight: '400', color: '#42a6ed' }}>{this.state.toggle ? "登入" : "Sign In"}</Text>
</View>
<Separator bordered>
<Text style={{ fontSize: 20, fontWeight: '400' }}>Language</Text>
</Separator>
<TouchableOpacity onPress={() => this.funcCallen()}>
<ListItem>
<Text>English</Text>
</ListItem>
</TouchableOpacity>
<TouchableOpacity onPress={() => { this.funcCallch() }}>
<ListItem last>
<Text>Chinese</Text>
</ListItem>
</TouchableOpacity>
<Separator bordered>
</Separator>
</Content>
</Container>
)
}
}
export default Settings
А вот другой компонент навигатора вкладок, где я хочу изменить состояние от выполнения предыдущих функций компонента funcCallen
и funcCallch
:
class Toolbox1 extends Component{
constructor(props) {
super(props);
this.state = {
toggle: false
}
}
componentWillMount() {
const { navigation } = this.props;
this.focusListener = navigation.addListener("didFocus", () => {
try {
const value = AsyncStorage.getItem('toggle')
this.setState({ toggle: JSON.parse(value) })
console.log('mate:', this.state.toggle)
} catch(e) {
// error reading value
}
});
}
render() {
console.log('new:', this.state.toggle)
return (
<Container>
<Header>
<Body style={{marginLeft:20}}>
<Title>Toolbox</Title>
</Body>
</Header>
<Content>
<ListItem onPress={()=> this.props.navigation.navigate('Toolbox')}>
<Icon name='stats' style={{color:'blue'}}/>
<Body>
<Text style={styles.text}>4D Number Stats & Detail</Text>
</Body>
</ListItem>
<ListItem onPress={()=> this.props.navigation.navigate('LuckySpin')}>
<Icon name='planet' style={{color:'blue'}}/>
<Body>
<Text style={styles.text}>{this.state.toggle ? "旋转我的运气" : "Spin My Luck"}</Text>
</Body>
</ListItem>
</Content>
</Container>
);
}
}
export default withNavigation(Toolbox1)
Теперь он не меняет состояние в Toolbox1
. Как я могу это сделать?