bae*_*ram 3 dart snackbar flutter
我正在为我的应用程序实现Bloc模式,并且我必须显示SnackBar,当未经身份验证的登录名显示错误消息。
但是我无法在小部件的构建阶段显示SnackBar。我寻找了很多解决方案,但找不到。
使用此功能的最有效方法是什么?
我的密码
import 'package:chat_app/auth/auth_bloc.dart';
import 'package:chat_app/auth/auth_state.dart';
import 'package:chat_app/main_page.dart';
import 'package:flutter/material.dart';
void main() => runApp(App());
class App extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Chat App',
home: MyApp(),
debugShowCheckedModeBanner: false,
);
}
}
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
final AuthBloc _bloc = AuthBloc();
final _emailController = TextEditingController();
final _passwordController = TextEditingController();
@override
void dispose() {
_emailController.dispose();
_passwordController.dispose();
_bloc.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
key: _scaffoldKey,
appBar: AppBar(title: Text('Chat Example')),
body: StreamBuilder(
initialData: AuthInitializing(),
stream: _bloc.authStream,
builder: (BuildContext context, AsyncSnapshot<AuthState> snapshot){
AuthState state = snapshot.data;
if(state is AuthUnauthenticated){
_showErrorMessage(state.errorMessage);
}
if(state is AuthAuthenticated){
_moveNextPage(context);
}
return Form(
key: _formKey,
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Column(
children: <Widget>[
TextFormField(
controller: _emailController,
keyboardType: TextInputType.emailAddress,
decoration: InputDecoration(
border: OutlineInputBorder(),
labelText: '???',
),
),
SizedBox(height: 20.0),
TextFormField(
controller: _passwordController,
keyboardType: TextInputType.text,
obscureText: true,
decoration: InputDecoration(
border: OutlineInputBorder(),
labelText: '????'
),
),
SizedBox(height: 20.0),
RaisedButton(
child: Text('???',style: TextStyle(color: Colors.white),),
onPressed: () => _bloc.addLoginData(_emailController.text, _passwordController.text),
color: Theme.of(context).primaryColor,
),
SizedBox(height: 15.0),
state is AuthLoading ? _progressBar() : Container()
],
),
),
);
},
),
);
}
void _showErrorMessage(String message){
_scaffoldKey.currentState.showSnackBar(SnackBar(
content: Text(message),
));
}
void _moveNextPage(BuildContext context) {
Navigator.pushReplacement(context, MaterialPageRoute(
builder: (_) => MainPage()
));
}
Widget _progressBar() {
return Center(
child: CircularProgressIndicator(),
);
}
}
Run Code Online (Sandbox Code Playgroud)
堆栈跟踪
I /颤振(30505):??? 小工具图书馆的例外情况???????????????????????????????????????????????? ??????????????? I / flutter(30505):在构建StreamBuilder时引发了以下断言(脏,状态:I / flutter(30505):_StreamBuilderBaseState>#bd8b2):I / flutter(30505):setState()或在构建期间调用的markNeedsBuild()。I / flutter(30505):无法将此Scaffold小部件标记为需要构建,因为该框架已在I / flutter(30505):构建小部件的过程中。可以在构建阶段I / flutter(30505)中将小部件标记为需要构建:仅当其祖先之一正在构建时。允许此异常是因为框架I / flutter(30505):在子代之前构建父窗口小部件,这意味着将始终构建脏后代。I / flutter(30505):否则,框架在此构建阶段可能不会访问此小部件。I / flutter(30505):调用了setState()或markNeedsBuild()的小部件是:I / flutter(30505):
支架-[LabeledGlobalKey#5bdc5](状态:ScafoldState#61be4(股票代码:跟踪2 I / flutter(30505):股票代码))
首先,必须确保始终返回小部件
然后您可以安排SnackBar帧的结尾
if(state is AuthUnauthenticated){
WidgetsBinding.instance.addPostFrameCallback((_) => _showErrorMessage(state.errorMessage));
return Container();
}
Run Code Online (Sandbox Code Playgroud)
您还应该检查数据是否data为null snapshot。
| 归档时间: |
|
| 查看次数: |
679 次 |
| 最近记录: |