概述

#

之前 FormFormField 小部件的自动验证 API 无法控制自动验证何时发生。因此,这些小部件的自动验证总是在首次构建时,当小部件首次对用户可见时发生,而您无法控制自动验证何时发生。

背景

#

由于原始 API 不允许开发人员更改自动验证行为,仅在用户与表单字段交互时进行验证,因此我们添加了新的 API,允许开发人员配置 FormFormField 小部件的自动验证行为。

变更说明

#

进行了以下更改:

  • autovalidate 参数已被弃用。
  • 添加了一个名为 autovalidateMode 的新参数,这是一个接受 AutovalidateMode 枚举类值的枚举。

迁移指南

#

要迁移到新的自动验证 API,您需要将已弃用的 autovalidate 参数的用法替换为新的 autovalidateMode 参数。如果您想要与之前相同的行为,可以使用:autovalidateMode = AutovalidateMode.always。这将使您的 FormFormField 小部件在首次构建时和每次更改时都自动验证。

迁移前的代码

dart
class MyWidget extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return FormField(
      autovalidate: true,
      builder: (FormFieldState state) {
        return Container();
      },
    );
  }
}

迁移后的代码

dart
class MyWidget extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return FormField(
      autovalidateMode: AutovalidateMode.always,
      builder: (FormFieldState state) {
        return Container();
      },
    );
  }
}

时间线

#

已于版本:1.21.0-5.0.pre 落地
稳定发布版本:1.22

参考资料

#

API 文档

相关问题

相关 PR