gpt4 book ai didi

dart - MainApp 根据值发送到页面

转载 作者:IT王子 更新时间:2023-10-29 07:05:31 25 4
gpt4 key购买 nike

我正在构建一个 Flutter 应用程序,当应用程序启动时,我想将用户发送到登录页面(如果尚未登录)或仪表板页面(如果已登录)。

基本上,main() 只是代码,没有小部件。我将如何做到这一点?

我想象的是这样的:

import 'package:flutter/material.dart';

void main() {
runApp(new MaterialApp(
home: new StarterPoint()
));
}

class StarterPoint extends StatelessWidget {
final bool loggedIn = false;

if (loggedIn) {
Navigator.push(
MaterialPageRoute(builder: (context) => Dashboard()),
);
} else {
Navigator.push(
MaterialPageRoute(builder: (context) => Login()),
);
}
}

最佳答案

这是您可以执行的操作的一个简单示例。我认为您需要根据您是否登录来跟踪 StarterPoint 中的状态。

import 'package:flutter/material.dart';

void main() {
runApp(MaterialApp(home: StarterPoint()));
}

class StarterPoint extends StatefulWidget {
@override
State<StatefulWidget> createState() => StarterPointState();
}

class StarterPointState extends State<StarterPoint> {
bool loggedIn = false;

@override
Widget build(BuildContext context) {
if (loggedIn) {
return Dashboard();
} else {
return Login(() => setState(() {
loggedIn = true;
}));
}
}
}

class Dashboard extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Text('hello!');
}
}

class Login extends StatelessWidget {
final Function() callBack;
Login(this.callBack);

@override
Widget build(BuildContext context) {
return Column(children: [
RaisedButton(child: Text('press'), onPressed: () => callBack())
]);
}
}

关于dart - MainApp 根据值发送到页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53654242/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com