- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在练习一个登录页面,几乎所有内容都已完成。现在,在后台清除应用程序后,使用户保持登录状态的原因是什么。我曾在flutter中尝试过sharedPreference,这有效。但是它仅在hotRestart而不在重启时才起作用。有人可以帮我吗?
这是sharedPreference类
import 'package:shared_preferences/shared_preferences.dart';
class HelperFunction {
static String sharedPreferenceUserLoggedInKey = 'userLoggedIn';
static String sharedPreferenceUserLoggedOutKey = 'userLoggedOut';
static String sharedPreferenceUserSignedUpKey = 'userSignedUp';
//saving data to sharedPreference
static Future<bool> saveUserLoggedInSharedPreference(
bool isUserLoggedIn) async {
SharedPreferences prefs = await SharedPreferences.getInstance();
return await prefs.setBool(sharedPreferenceUserLoggedInKey, isUserLoggedIn);
}
static Future<bool> saveUserSignedUpSharedPreference(
bool isUserSignUp) async {
SharedPreferences prefs = await SharedPreferences.getInstance();
return await prefs.setBool(sharedPreferenceUserSignedUpKey, isUserSignUp);
}
static Future<bool> saveUserLoggedOutSharedPreference(
bool isUserLoggedOut) async {
SharedPreferences prefs = await SharedPreferences.getInstance();
return await prefs.setBool(
sharedPreferenceUserLoggedOutKey, isUserLoggedOut);
}
//getting data to sharedPreference
static Future<bool> getUserLoggedInSharedPreference() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
return await prefs.getBool(sharedPreferenceUserLoggedInKey);
}
static Future<bool> getUserLoggedOutSharedPreference() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
return await prefs.getBool(sharedPreferenceUserLoggedOutKey);
}
static Future<bool> getUserSignedUpSharedPreference() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
return await prefs.getBool(sharedPreferenceUserSignedUpKey);
}
}
登录按钮已按下功能
FlatButton(
onPressed:(){
HelperFunction.saveUserLoggedInSharedPreference(true);
HelperFunction.saveUserSignedUpSharedPreference(false);
HelperFunction.saveUserLoggedOutSharedPreference(false);
Navigator.pushReplacement(
context,
MaterialPageRoute(
builder: (context) => DashBoard(),
),
);
}
),
注册按钮onPressed功能:
FlatButton(
onPressed:(){
HelperFunction.saveUserLoggedInSharedPreference(false);
HelperFunction.saveUserSignedUpSharedPreference(true);
HelperFunction.saveUserLoggedOutSharedPreference(false);
Navigator.pop(context);
}
}
)
退出按钮onPressed功能:
FlatButton(
onPressed:(){
HelperFunction.saveUserLoggedOutSharedPreference(true);
HelperFunction.saveUserLoggedInSharedPreference(false);
HelperFunction.saveUserSignedUpSharedPreference(false);
Navigator.pop(context);
}
}
)
这是我的主要功能
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle.light
.copyWith(systemNavigationBarColor: Colors.black));
runApp(
DevicePreview(
enabled: kReleaseMode,
builder: (context) => FlashChat(),
),
);
}
class FlashChat extends StatefulWidget {
@override
_FlashChatState createState() => _FlashChatState();
}
class _FlashChatState extends State<FlashChat> {
bool isUserLoggedIn;
bool isUserSignedUp;
bool isUserLoggedOut;
void getLoggedInStatus() async {
await HelperFunction.getUserLoggedInSharedPreference().then((value) {
isUserLoggedIn = value;
print('isUserLoggedIn = $isUserLoggedIn');
});
}
void getSignedUpStatus() async {
await HelperFunction.getUserSignedUpSharedPreference().then((value) {
isUserSignedUp = value;
print('isUserSignedUp = $isUserSignedUp');
});
}
void getLoggedOutStatus() async {
await HelperFunction.getUserLoggedOutSharedPreference().then((value) {
isUserLoggedOut = value;
print('isUserLoggedOut = $isUserLoggedOut');
});
}
@override
void initState() {
getLoggedInStatus();
getSignedUpStatus();
getLoggedOutStatus();
super.initState();
}
@override
Widget build(BuildContext context) {
return LayoutBuilder(builder: (context, constraints) {
return OrientationBuilder(builder: (context, orientation) {
SizeConfig().init(constraints, orientation);
return MaterialApp(
home: isUserLoggedIn == true
? DashBoard()
: isUserSignedUp == true
? LoginScreen()
: isUserLoggedOut == true ? LoginScreen() : WelcomeScreen(),
debugShowCheckedModeBanner: false,
);
});
});
}
}
最佳答案
经过长时间的搜索,我找到了答案。通过将值放在setState中,我解决了我的问题。
import 'package:firebase_core/firebase_core.dart';
import 'package:flash/helper/helper_function.dart';
import 'package:flash/screens/dash_board_screen.dart';
import 'package:flash/screens/forgot_password_screen.dart';
import 'package:flash/screens/welcome_screen.dart';
import 'package:flash/size_configuration.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:flash/screens/login_screen.dart';
import 'package:flash/screens/registration_screen.dart';
import 'package:flash/screens/chat_screen.dart';
import 'package:device_preview/device_preview.dart';
import 'package:flutter/services.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle.light
.copyWith(systemNavigationBarColor: Colors.black));
runApp(
DevicePreview(
enabled: kReleaseMode,
builder: (context) => FlashChat(),
),
);
}
class FlashChat extends StatefulWidget {
@override
_FlashChatState createState() => _FlashChatState();
}
class _FlashChatState extends State<FlashChat> {
bool isUserLoggedIn;
bool isUserSignedUp;
bool isUserLoggedOut;
@override
void initState() {
getLoggedInStatus();
getSignedUpStatus();
getLoggedOutStatus();
super.initState();
}
void getLoggedInStatus() async {
await HelperFunction.getUserLoggedInSharedPreference().then((value) {
setState(() {
isUserLoggedIn = value;
});
print('isUserLoggedIn = $isUserLoggedIn');
});
}
void getSignedUpStatus() async {
await HelperFunction.getUserSignedUpSharedPreference().then((value) {
setState(() {
isUserSignedUp = value;
});
print('isUserSignedUp = $isUserSignedUp');
});
}
void getLoggedOutStatus() async {
await HelperFunction.getUserLoggedOutSharedPreference().then((value) {
setState(() {
isUserLoggedOut = value;
});
print('isUserLoggedOut = $isUserLoggedOut');
});
}
@override
Widget build(BuildContext context) {
return LayoutBuilder(builder: (context, constraints) {
return OrientationBuilder(builder: (context, orientation) {
SizeConfig().init(constraints, orientation);
return MaterialApp(
home: isUserLoggedIn == true
? DashBoard()
: isUserSignedUp == true || isUserLoggedOut == true
? LoginScreen()
: WelcomeScreen(),
debugShowCheckedModeBanner: false,
);
});
});
}
}
关于flutter - 我正在尝试让用户登录,但是我的代码仅在应用程序热重启后才有效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63787721/
我有一个 UWP 应用程序(在 Windows/Microsoft Store 中发布),我正在进行新的更新,我在我的应用程序中使用了 Template10,它具有深色和浅色主题,并且在 Window
我是 spring batch 的新手,有一些关于暂停/恢复的问题。看了spring batch的文档,好像没有内置的pause或者resume功能。但是,我从主站点找到了这个用例: http://d
我正在编写一个网络服务并有以下观察结果:即使我只是将一个文本文件添加到存储 web 服务引用的所有 dll 的目录 (bin),appdomain 也会刷新。 这会导致存储在字典(在其中一个 dll
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
Hadoop 1.0.3 工作 36 小时后说: INFO mapred.JobClient: map 42% reduce 0% mapred.JobClient: Job Failed
我使用 AVAssetWriter 将视频录制到文件中。所以我为此创建了类。 link to gist 然后在项目的某处我推送记录并开始录制视频。 func start() { assetWriter
我想要一个在后台运行的 python 脚本(无限循环)。 def main(): # inizialize and start threads [...] try:
我在重新启动 Activity 时感到困惑。我有两个功能可以很好地完成同一任务。请指导我哪个最好,为什么? public void restart() { Intent
重启sidekiq的正确方法是什么。它似乎在我启动它时缓存了我的 worker 代码,所以每次我对我的 worker 进行更改时我都需要重新启动它。我正在使用 Ctrl/C 执行此操作,但该过程需要很
我在我的 Android 模拟器上安装了新字体。说明说我必须重新启动设备。我尝试使用“关机”按钮,但它只显示“正在关机”并且什么也不做。即使我去 adb shell 并运行“重启”它也会挂起。 任何想
启动操作 ? 1
关闭 service nginx stop systemctl stop nginx 启动 service nginx start systemctl start n
正在学习Linux中。。。一边学一边记录着。。所有观点只是个人观点 Linux有个文件 /etc/inittab 复制代码 代码如下:
如果我运行 systemctl restart kubelet它会影响其他正在运行的节点吗?它会停止集群吗?你能预见任何影响吗? 任何帮助,将不胜感激! 最佳答案 在回答之前,小声明:重启不是由于对
嗯,问题是我有一个在 MATE 上完美运行的 Abyssus Razer,但是 在 Debian、Elementary、OpenSUSE 和其他平台上,默认 设置 super 慢。 我用 解决了这个问
我在 Ubuntu 16.04 上安装了 NGINX 并编辑了我的配置。 当我想用 sudo service nginx restart 重新启动时我得到错误: Job for nginx.servi
我已经在我的 Ubuntu 上安装了 Gearman Job Server(又名 Gearmand)1.0.6: Distributor ID: Ubuntu Description: Ubun
我有一个 WiX Burn使用 ManagedBootstrapperApplicationHost 的自定义安装程序。安装必备 Microsoft Windows Installer 之一后4.5
我已经使用 brew install mosquitto 在我的 mac 上安装了蚊子代理. 通常我不会给出任何命令来启动 mosquitto 服务器。当我打开我的 mac 时它会自动启动。 我已经使
我有一个带有 2 个容器的 pod test-1495806908-xn5jn。我想重新启动其中一个名为 container-test 的项目。是否可以重新启动 Pod 中的单个容器以及如何重新启动?
我是一名优秀的程序员,十分优秀!