我創建了這樣的布局,問題是 onPressed 偵聽器不起作用,但我不明白為什么:
Material(
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(22.0)),
color: const Color.fromRGBO(33, 63, 132, 1),
clipBehavior: Clip.antiAlias,
child: MaterialButton(
height: 140.0,
minWidth: 380.0,
elevation: 20.0,
color: const Color.fromRGBO(33, 63, 132, 1),
textColor: Colors.white,
child: Text("Chiudi sessione / Cambia utente",
style: TextStyle(
fontSize: ScreenUtil().setSp(20),
)),
onPressed: () {
var future = endUserSession(badgeCode, false, context);
future.then((value) {
setUserBadgeForDualMode("");
setDoorStatusIntoPrefs("");
Navigator.pushReplacement(context, MaterialPageRoute(builder: (context) => const OpenDoorDualMode()));
});
}
),
)
我究竟做錯了什么?
uj5u.com熱心網友回復:
問題似乎出在您的函式呼叫上,您不是在等待將來的值,請以這種方式使用
var future = await endUserSession(badgeCode, false, context);
或嘗試洗掉它并像這樣呼叫您的函式
await endUserSession(badgeCode, false, context).then((value) async {
await setUserBadgeForDualMode("");
await setDoorStatusIntoPrefs("");
Navigator.pushReplacement(context, MaterialPageRoute(builder: (context) => const OpenDoorDualMode()));
});
在您期望未來值的任何地方使用“等待”。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/421133.html
標籤:
