【发布时间】:2021-06-20 22:29:54
【问题描述】:
我的流程如下。屏幕只有两个元素 - TextFormField 和 ElevatedButton。
- 从用户那里获取电子邮件地址
- 用户点击按钮
- 按钮验证输入,然后
- 调用 FutureBuilder,它
- 尝试从 REST API 获取客户端记录
- 重定向到适当的路线
这是我的第一个 Flutter/Dart 程序仅供参考,所以我可能会犯一个初学者的错误。
问题:FutureBuilder 的第一行没有执行。没有错误,没有消息,什么都没有。为什么会发生这种情况?
用户输入邮箱地址,点击按钮,fetchClientInfo函数被执行,返回一个Future<ClientInfo>,就是这样。
你能帮忙吗?
@override
Widget build(BuildContext context) {
final _formKey = GlobalKey<FormState>();
return Scaffold(
appBar: AppBar(
title: Text("Register Profile"),
),
body: Form(
key: _formKey,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Padding(
padding: EdgeInsets.all(20),
child: TextFormField(
controller: emailController,
validator: (email) {
if (email.isEmpty) {
return 'Please enter your email address.';
} else if (!EmailValidator.validate(email)) {
return 'Please enter a valid email address.';
}
return null;
},
decoration: InputDecoration(
border: new UnderlineInputBorder(borderSide: new BorderSide(color: Colors.red)),
labelText: 'Email',
hintText: 'Enter your email address',
contentPadding: EdgeInsets.all(20.0),
),
)),
ElevatedButton(
onPressed: () => {
if (_formKey.currentState.validate())
{
FutureBuilder<ClientInfo>(
future: fetchClientInfo(emailController.text),
builder: (BuildContext context, snapshot) {
print("here");
if (snapshot.data.outcome) {
return Text("main screen");
} else if (!snapshot.data.outcome) {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) =>
RegisterNewUser(emailAddress: emailController.text)));
} else if (snapshot.hasError) {
return Text("${snapshot.error}");
}
// Show a spinner
return CircularProgressIndicator();
},
)
}
},
child: Text(
"Check Email",
))
])));
}
Future<ClientInfo> fetchClientInfo(String emailAddress) async {
var url = Uri.https(APIAccess.baseAPIURL, APIAccess.pathToClientAPI, {
'client_id': '$emailAddress',
'action': 'info',
'key': '${APIAccess.key}'
});
final response = await http.get(url);
if (response.statusCode == 200) {
return ClientInfo.fromJson(jsonDecode(response.body));
} else {
throw Exception('Failed to load album');
}
}
【问题讨论】:
-
你能显示 fetchClientInfo 吗?
-
@LOLWTFasdasdasdad 已更新,谢谢。
标签: flutter dart flutter-futurebuilder