gpt4 book ai didi

dart - setState 不更新界面

转载 作者:IT王子 更新时间:2023-10-29 07:08:33 26 4
gpt4 key购买 nike

我正在尝试学习 flutter,但他已经妨碍我一个多星期了,我无法让 setState 正常工作。

在这种情况下,我想按下一个按钮并更改它的图标和属性,基本上有另一个元素,但我就是无法让它工作。

这是我的小部件代码:

import 'package:flutter/material.dart';

class UserButton extends StatefulWidget {
@override
_UserButtonState createState() => _UserButtonState();
}

class _UserButtonState extends State<UserButton> {
@override
Widget build(BuildContext context) {
bool loggedin = false;
return Container(
child: loggedin
? IconButton(
onPressed: () {
setState(() {
loggedin = false;
});
},
icon: Icon(Icons.person),
)
: IconButton(
onPressed: () {
setState(() {
loggedin = true;
});
},
icon: Icon(Icons.person_outline),
tooltip: "Login",
));
}
}

这是主要的应用程序代码:

import 'package:flutter/material.dart';

import 'package:orar/user_button.dart';

main(List<String> args) {
runApp(Home());
}

class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}

class _HomeState extends State<Home> {
@override
Widget build(BuildContext context) {
return MaterialApp(
theme:
ThemeData(primaryColor: Colors.cyan, accentColor: Colors.cyanAccent),
home: Scaffold(
appBar: AppBar(
title: Text("test"),
actions: <Widget>[UserButton()],
),
body: ListView(
children: <Widget>[],
),
),
);
}
}

最佳答案

loggedin 应该是状态变量。在您的情况下,它是构建方法中的局部变量。

loggedin 移出 build 方法,它应该可以工作

关于dart - setState 不更新界面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53802882/

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