- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
initState() 在我路由到的第一个 Widget 上被调用了两次。
我已经删除了 initState() 方法中的所有方法调用和正在完成的工作,以排除它以某种方式调用自身的任何可能性。它所做的只是调用 super.initState()。
routes.dart:
final routes = {
'/login' : (BuildContext context) => new LoginPage(),
'/' : (BuildContext context) => new LoginPage()
};
主飞镖:
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Personnel Ledger',
initialRoute: '/login',
routes: routes,
theme: ThemeData(
scaffoldBackgroundColor: Color(0xFF30778B)
),
);
}
}
登录页面.dart:
class LoginPage extends StatefulWidget {
@override
LoginPageState createState() => LoginPageState();
}
class LoginPageState extends State<LoginPage> {
TextEditingController emailTextfieldCtrl;
TextEditingController passwordTextfieldCtrl;
AuthHttpService authHttpService;
bool loggaInDisabled;
Widget invalidCredentialsText;
@override
void initState() {
super.initState();
// setInvalidCredentialsTextVisibleWithoutSetState(false);
// authHttpService = new AuthHttpService();
// emailTextfieldCtrl = new TextEditingController();
// passwordTextfieldCtrl = new TextEditingController();
loggaInDisabled = true;
// refreshApplicationAccessToken();
}
@override
Widget build(BuildContext context) {
return Scaffold(
resizeToAvoidBottomPadding: false,
body: SafeArea(
child: Stack(
children: <Widget>[
Container(
decoration: BoxDecoration(
gradient: LinearGradient(
begin: Alignment.topLeft,
end: Alignment.bottomRight,
colors: [Color(0xFF30778B), Color(0xFF2F3648)])),
child: Center(
child: Stack(
children: <Widget>[
Column(
children: <Widget>[
Spacer(
flex: 11,
),
Flexible(
flex: 50,
child: Container(
child: Image.asset("assets/knowe-logo.png"),
),
),
],
),
Column(
mainAxisSize: MainAxisSize.min,
children: <Widget>[
Spacer(
flex: 35,
),
Flexible(
flex: 10,
child: Container(
child: Row(
children: <Widget>[
Spacer(
flex: 1,
),
Flexible(
flex: 7,
child: Theme(
data:
ThemeData(hintColor: Color(0xFF9E9C9C)),
child: TextField(
style:
TextStyle(color: Color(0xFF9E9C9C)),
cursorColor: Color(0xFF9E9C9C),
controller: emailTextfieldCtrl,
onChanged: emailTextfieldChanged,
decoration: InputDecoration(
prefixIcon: Icon(
Icons.person,
size: 30,
color: Color(0xFF9E9C9C),
),
labelText: "Email",
border: new UnderlineInputBorder(
borderSide: BorderSide(
color: Color(0xFF9E9C9C),
style: BorderStyle.solid,
width: 2))),
),
),
),
Spacer(
flex: 1,
)
],
),
),
),
Flexible(
flex: 10,
child: Container(
margin: EdgeInsets.only(top: 5),
child: Row(
children: <Widget>[
Spacer(
flex: 1,
),
Flexible(
flex: 7,
child: Theme(
data:
ThemeData(hintColor: Color(0xFF9E9C9C)),
child: TextField(
obscureText: true,
style:
TextStyle(color: Color(0xFF9E9C9C)),
cursorColor: Color(0xFF9E9C9C),
controller: passwordTextfieldCtrl,
onChanged: passwordTextfieldChanged,
decoration: InputDecoration(
prefixIcon: Icon(
Icons.lock,
size: 26,
color: Color(0xFF9E9C9C),
),
labelText: "Lösenord",
border: new UnderlineInputBorder(
borderSide: BorderSide(
color: Color(0xFF9E9C9C),
style: BorderStyle.solid,
width: 2))),
),
),
),
Spacer(flex: 1)
],
),
),
),
Flexible(
flex: 10,
child: Container(
child: invalidCredentialsText,
)),
Flexible(
flex: 20,
child: Container(
margin: EdgeInsets.only(top: 0),
child: Row(
children: <Widget>[
Spacer(
flex: 1,
),
Expanded(
flex: 7,
child: Container(
height: 50,
child: RaisedButton(
disabledColor: Color(0xff395A52),
child: Text(
"Logga in",
style: TextStyle(
color: loggaInDisabled
? Color(0xff7a7a7a)
: Colors.white),
),
onPressed: loggaInDisabled
? null
: loggaInPressed,
color: Color(0xff10846D),
),
),
),
Spacer(flex: 1)
],
),
),
),
Container(
margin: EdgeInsets.only(top: 7.5),
child: InkWell(
child: Text(
"Glömt lösenord?",
style: TextStyle(color: Color(0xFF9E9C9C)),
),
onTap: glomtLosenordPressed,
),
),
Spacer(
flex: 10,
),
],
)
],
),
),
),
Column(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.end,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Expanded(
child: Column(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.end,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Container(
alignment: Alignment.bottomLeft,
padding: EdgeInsets.only(left: 15, bottom: 10),
color: Colors.transparent,
child: InkWell(
onTap: privacyPolicyTapped,
child: Text("Privacy policy",
style: TextStyle(
color: Color(0xFF9E9C9C),
fontSize: 15,
decoration: TextDecoration.underline)),
),
)
],
),
)
],
)
],
),
),
);
}
setInvalidCredentialsTextVisible(bool show) {
setState(() {
if (show)
invalidCredentialsText = Row(
children: <Widget>[
Spacer(flex: 1),
Flexible(
flex: 7,
child: Column(
children: <Widget>[
Flexible(
flex: 4,
child: Container(
alignment: Alignment.centerLeft,
child: Row(
children: <Widget>[
Flexible(
flex: 1,
child: Icon(
Icons.error,
size: 20,
color: Color(0xFF9E9C9C),
),
),
Flexible(
flex: 5,
child: Container(
padding: EdgeInsets.only(left: 2.5),
child: Text(
"Invalid email or password",
style: TextStyle(color: Color(0xFF9E9C9C)),
),
),
)
],
),
),
),
Spacer(
flex: 2,
)
],
),
),
Spacer(flex: 1)
],
);
else
invalidCredentialsText = Row(
children: <Widget>[
Spacer(flex: 1),
Flexible(
flex: 7,
child: Column(
children: <Widget>[
Flexible(
flex: 3,
child: Container(
alignment: Alignment.centerLeft,
child: Row(
children: <Widget>[
Flexible(
flex: 1,
child: Icon(
Icons.error,
size: 20,
color: Color(0x009E9C9C),
),
),
Flexible(
flex: 5,
child: Container(
padding: EdgeInsets.only(left: 2.5),
child: Text(
"",
style: TextStyle(color: Color(0xFF9E9C9C)),
),
),
)
],
),
),
),
Spacer(
flex: 2,
)
],
),
),
Spacer(flex: 1)
],
);
});
}
setInvalidCredentialsTextVisibleWithoutSetState(bool show) {
if (show)
invalidCredentialsText = Row(
children: <Widget>[
Spacer(flex: 1),
Flexible(
flex: 7,
child: Column(
children: <Widget>[
Flexible(
flex: 4,
child: Container(
alignment: Alignment.centerLeft,
child: Row(
children: <Widget>[
Flexible(
flex: 1,
child: Icon(
Icons.error,
size: 20,
color: Color(0xFF9E9C9C),
),
),
Flexible(
flex: 5,
child: Container(
padding: EdgeInsets.only(left: 2.5),
child: Text(
"Invalid email or password",
style: TextStyle(color: Color(0xFF9E9C9C)),
),
),
)
],
),
),
),
Spacer(
flex: 2,
)
],
),
),
Spacer(flex: 1)
],
);
else
invalidCredentialsText = Row(
children: <Widget>[
Spacer(flex: 1),
Flexible(
flex: 7,
child: Column(
children: <Widget>[
Flexible(
flex: 3,
child: Container(
alignment: Alignment.centerLeft,
child: Row(
children: <Widget>[
Flexible(
flex: 1,
child: Icon(
Icons.error,
size: 20,
color: Color(0x009E9C9C),
),
),
Flexible(
flex: 5,
child: Container(
padding: EdgeInsets.only(left: 2.5),
child: Text(
"",
style: TextStyle(color: Color(0xFF9E9C9C)),
),
),
)
],
),
),
),
Spacer(
flex: 2,
)
],
),
),
Spacer(flex: 1)
],
);
}
privacyPolicyTapped() {
launch("https://www.knowe.se/policy.html");
}
emailTextfieldChanged(String newEmail) {
setState(() {
loggaInDisabled = shouldDisableLoggaIn();
});
}
passwordTextfieldChanged(String newPassword) {
setState(() {
loggaInDisabled = shouldDisableLoggaIn();
});
}
bool shouldDisableLoggaIn() {
var email = emailTextfieldCtrl.text;
var password = passwordTextfieldCtrl.text;
return !(email != null &&
email != "" &&
password != null &&
password != "");
}
loggaInPressed() {
logIn();
}
logIn() {
var email = emailTextfieldCtrl.text;
var password = passwordTextfieldCtrl.text;
var appId = "4d45d54d45d45dd45d45d54d54d54d54";
var response = authHttpService.logIn(email, password, appId);
onLoading();
response
.then((response) async {
Navigator.pop(context);
if (response.statusCode == 200) {
setInvalidCredentialsTextVisible(false);
var tokensModel = TokensModel.fromJson(json.decode(response.body));
final prefs = await SharedPreferences.getInstance();
prefs.setString("RefreshToken", tokensModel.refreshToken);
prefs.setString(
"ApplicationAccessToken", tokensModel.appAccessToken);
navigateToMainMenuPage();
} else
setInvalidCredentialsTextVisible(true);
})
.timeout(Duration(seconds: 10))
.catchError((error) {
Navigator.pop(context);
showMessageDialog(
"Fel vid inloggning", "Kunde inte få kontakt med servern.");
});
}
configureFCM() {
// var fcmHelper = new FCMHelper();
// fcmHelper.configureFCM(context);
// fcmHelper.registerFCMToken(userModel);
}
glomtLosenordPressed() {
navigateToResetPasswordPage();
}
refreshApplicationAccessToken() async {
var prefs = await SharedPreferences.getInstance();
var refreshToken = prefs.getString("RefreshToken");
if (refreshToken != null && refreshToken != "") {
var response =
authHttpService.refreshApplicationAccessToken(refreshToken);
onLoading();
response
.then((response) async {
Navigator.pop(context);
if (response.statusCode == 200) {
var tokensModel =
TokensModel.fromJson(json.decode(response.body));
var applicationAccessToken = tokensModel.appAccessToken;
var prefs = await SharedPreferences.getInstance();
prefs.setString("ApplicationAccessToken", applicationAccessToken);
navigateToMainMenuPage();
} else
showMessageDialog("Inloggningssessionen utgången",
"Logga in igen med dina uppgifter.");
})
.timeout(Duration(seconds: 10))
.catchError((error) {
Navigator.pop(context);
showMessageDialog(
"Fel vid inloggning", "Kunde inte få kontakt med servern.");
});
}
}
navigateToMainMenuPage() {
Navigator.push(
context,
MaterialPageRoute(builder: (context) => MainMenuPage()),
);
}
navigateToResetPasswordPage() {
Navigator.push(
context,
MaterialPageRoute(builder: (context) => ResetPasswordPage()),
);
}
void onLoading() {
showDialog(
context: context,
barrierDismissible: false,
builder: (_) => Scaffold(
backgroundColor: Color.fromRGBO(0, 0, 0, 0.25),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Container(
width: 40,
height: 40,
child: CircularProgressIndicator(strokeWidth: 5)),
Container(
margin: EdgeInsets.only(top: 15),
child: Text(
"Loggar in...",
style: TextStyle(color: Colors.white, fontSize: 20),
),
)
],
),
)),
);
}
void showMessageDialog(String title, String body) {
try {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: new Text(title),
content: new Text(body),
);
});
} catch (e) {
print(e.toString());
}
}
}
实际结果:LoginPage 中的 initState() 方法被调用了两次。
预期结果和目标:initState() 应该只被调用一次。
最佳答案
这是两个事实的结合:
/
不与 /login
共享状态,因此从 /
到 /login
将触发 /login
的 LoginPage
上的 initState
。initialRoute: '/login'
并不意味着应用在 /login
上直接启动。通过 /foo/bar
的 initialRoute
参数,应用程序将从以下路线历史开始:
/
/foo
/foo/bar
因此,即使您有一个 initialRoute
属性,/
仍然会被推送。
关于flutter - 为什么 initState() 被调用了两次?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56145378/
在文档中是这样写的,但我无法理解。 Called when this object is inserted into the tree. The framework will call this me
我正在 initstate 中通过 RestAPI 创建一个企业列表。我需要使用 sharedpreference 值作为其参数之一,但是当我尝试加载数据时,sharepreference 值初始为空
看看这段代码 - 用于获取数据并显示在列表中的小部件: class _MyEventsFragmentState extends State { var events; @override
在我的应用程序中,我有一个抽屉导航,正文根据抽屉中按下的磁贴进行更新。每个类的主体都是相同的,它是一个有状态的小部件并返回一个 ListView 。对于此类的每个实例(以及每个图 block ),我需
我正在使用 initState 并遇到 Navigator 问题: I/flutter ( 5726): The following assertion was thrown building Bui
一直在学习处理flutter中的async函数。我定义了一个 async 函数,并在两个地方调用了它 1。来自 build 函数。 2.来自 initState。 当从 build 函数调用时,函数被
我想在 initState 中创建一个 TextController,然后像处理好 child 一样处理它。但出于某种原因, Controller 在 intiState 之外不可用: class _
我在 initState() 中调用异步函数,但系统实际上等待异步函数的结果。谁能告诉我为什么? 这是我的代码: import 'package:flutter/material.dart'; voi
这个问题在这里已经有了答案: Is there a way to load async data on InitState method? (14 个回答) 2个月前关闭。 Flutter - 有没有
我正在创建 TextEditingController ,并初始化它,我可以做 class _HomePageState extends State { var _controller = Tex
在多次调用的选项卡 initstate() 之间切换。 我的标签栏 A、B、C 和 D 中有 4 个标签。 情况 (1) 如果我像从选项卡 A 切换到选项卡 B 那样切换选项卡,则它工作正常。 情况
我不知道在哪里调用 super.initSate()在 flutter ?在某些代码示例中,它在开头调用,而在其他代码示例中则在结尾调用。有区别吗? 我试图用谷歌搜索,但没有找到关于这个函数调用位置的
我有以下方法: getCalendarEventList() async { print('here we go agsain'); await Firestore.instanc
我是 Flutter 的新手,遇到了一个问题。 我的应用中有一个 Feed 模型,如下所示: import 'package:uuid/uuid.dart'; class Feed { // St
在 StatefulWidget 中制作 AnimationController final 的最佳方法是什么,以下代码会出错。 final AnimationController _controll
我正在 initState(){} 中初始化一个变量: @override void initState() { getDataFromFirestore(); super.ini
我正在开发这个应用程序,您可以在其中导航到带有状态小部件的屏幕,该小部件具有在 initState() 中运行的一堆复杂函数。 由于这些功能,触发导航功能后导航到此屏幕需要将近两秒钟,即非常慢 我的代
我正在使用 Flutter 创建一个应用程序。我想从 firebase 获取数据并显示 GridView 。数据从 firebase 正确获取。 initState() 中的数据获取 但它并没有更新另
initState() 在我路由到的第一个 Widget 上被调用了两次。 我已经删除了 initState() 方法中的所有方法调用和正在完成的工作,以排除它以某种方式调用自身的任何可能性。它所做的
每次我离开一个小部件然后返回到它时,我都会收到对该小部件的 initState 方法的“n+1”次调用。 我的设置与此类似。我从小部件 A 开始,当识别到对卡片的点击时,我们执行 Navigator.
我是一名优秀的程序员,十分优秀!