React Native:仅在导航到新页面完成后才禁用 Activity 指示器
ReactNative: Disable the Activity Indicator only after navigation to a new page is completed
我是 React Native 的新手。我已经编写了登录页面和个人资料页面。
在 Login.js 页面我有状态:
this.state = {
email: '',
password: '',
authenticating: false,
}
输入正确的详细信息后点击登录按钮后,将执行 loginUser 函数:
loginUser = (email, password) => {
this.setState({ authenticating: true });
try {
firebase.auth().signInWithEmailAndPassword(email, password)
.then((user) => {
this.props.navigation.navigate('Profile');
this.setState({ authenticating: false });
});
}
catch (error) {
console.log(error.toString());
}
}
下面是我的渲染函数:
renderCurrentState() {
if (this.state.authenticating) {
return (
<View>
<ActivityIndicator size='large' />
</View>
)
}
return (
<View>
<Input
placeholder='Enter your Email...'
label='Email'
onChangeText={email => this.setState({ email })}
value={this.state.email}
/>
<Input
placeholder='Enter your Password...'
label='Password'
secureTextEntry
onChangeText={password => this.setState({ password })}
value={this.state.password}
/>
<Button
onPress={() => this.loginUser(this.state.email, this.state.password)}
>Log in</Button>
<Button
onPress={() => this.signUpUser(this.state.email, this.state.password)}
>Sign upp</Button>
</View>
)
}
问题是我点击登录按钮后,它开始显示 activity 指示器,但就在显示 'Profile' 页面之前,它再次显示 'Login' 页面几毫秒我不想要。
对此有任何帮助。我不想像这样设置 setTimeOut 延迟解决方案:
setTimeout(()=>{ this.setState({ authenticating: false }) }, 100)
如果有人可以为此提供代码。这会很有帮助。
React-navigation 现在有生命周期挂钩。您可以等待当前屏幕变模糊,以便您知道转换已完成。
navigateAsync = (routeName) => {
const promise = new Promise(resolve => {
const subscription = this.props.navigation.addListener('didBlur', () => {
subscription.remove();
resolve();
});
});
this.props.navigation.navigate(routeName);
return promise;
};
然后你就可以调用
this.navigateAsync('Profile').then(() => {
this.setState({ authenticating: false });
})
我是 React Native 的新手。我已经编写了登录页面和个人资料页面。
在 Login.js 页面我有状态:
this.state = {
email: '',
password: '',
authenticating: false,
}
输入正确的详细信息后点击登录按钮后,将执行 loginUser 函数:
loginUser = (email, password) => {
this.setState({ authenticating: true });
try {
firebase.auth().signInWithEmailAndPassword(email, password)
.then((user) => {
this.props.navigation.navigate('Profile');
this.setState({ authenticating: false });
});
}
catch (error) {
console.log(error.toString());
}
}
下面是我的渲染函数:
renderCurrentState() {
if (this.state.authenticating) {
return (
<View>
<ActivityIndicator size='large' />
</View>
)
}
return (
<View>
<Input
placeholder='Enter your Email...'
label='Email'
onChangeText={email => this.setState({ email })}
value={this.state.email}
/>
<Input
placeholder='Enter your Password...'
label='Password'
secureTextEntry
onChangeText={password => this.setState({ password })}
value={this.state.password}
/>
<Button
onPress={() => this.loginUser(this.state.email, this.state.password)}
>Log in</Button>
<Button
onPress={() => this.signUpUser(this.state.email, this.state.password)}
>Sign upp</Button>
</View>
)
}
问题是我点击登录按钮后,它开始显示 activity 指示器,但就在显示 'Profile' 页面之前,它再次显示 'Login' 页面几毫秒我不想要。
对此有任何帮助。我不想像这样设置 setTimeOut 延迟解决方案:
setTimeout(()=>{ this.setState({ authenticating: false }) }, 100)
如果有人可以为此提供代码。这会很有帮助。
React-navigation 现在有生命周期挂钩。您可以等待当前屏幕变模糊,以便您知道转换已完成。
navigateAsync = (routeName) => {
const promise = new Promise(resolve => {
const subscription = this.props.navigation.addListener('didBlur', () => {
subscription.remove();
resolve();
});
});
this.props.navigation.navigate(routeName);
return promise;
};
然后你就可以调用
this.navigateAsync('Profile').then(() => {
this.setState({ authenticating: false });
})