0

我在该函数中有一个 Future 布尔函数,我使用 map 函数检查了一些数据。if 和 else 两个条件都设置布尔变量为真。但它总是返回默认的 false 值。下面的代码是我的功能。

  Future<bool> checkisShowablebydepend(Questions questions) async {
    bool isDependvalue = false;

    questions.dependFields.map((e) async {
      bool isequal = (questions.dependValue.toLowerCase() ==
          _formKey.currentState.fields[e].value.toLowerCase());

      if (isequal) {
        isDependvalue = true;
      } else {
        isDependvalue = true;
      }
    });

    return isDependvalue;
  }

这就是我从上述函数获取数据的方式。

  Widget loadWidgets(Questions questions) {
    if (questions.depend) {
      return FutureBuilder<bool>(
          future: checkisShowablebydepend(questions),
          builder: (BuildContext context, AsyncSnapshot<bool> snapshot) {
            switch (snapshot.connectionState) {
              case ConnectionState.none:
                return new Text('Press button to start');
              case ConnectionState.waiting:
                return new Text('Awaiting result...');
              default:
                if (snapshot.hasError)
                  return new Text('Error: ${snapshot.error}');
                else
                  return new Text('Result: ${snapshot.data}');
            }
          });
    } else {
      return selectFormfield(questions);
    }
  }
4

2 回答 2

0

Async意味着此函数是异步的,您可能需要稍等片刻才能得到它的结果。

Await意思是 - 在这里等到这个函数完成,你会得到它的返回值。

await 关键字仅适用于异步函数。

您已将功能设置为sync可以使用await关键字等待比较结果

questions.dependFields.map((e) async {
      bool isequal = await (questions.dependValue.toLowerCase() ==
          _formKey.currentState.fields[e].value.toLowerCase());

      if (isequal) {
        isDependvalue = true;
      } else {
        isDependvalue = true;
      }
    });
于 2021-04-27T05:19:10.403 回答
0

如果您的目标是遍历您的questions.dependFields列表,那么forEach似乎更合适。

我不确定这个功能是否需要Future顺便说一句。

于 2021-04-27T05:18:31.730 回答