Skip to main content

v1.22 后移除的已弃用 API

摘要

#

根据 Flutter 的弃用策略,在 1.22 稳定版发布后达到生命周期结束的已弃用 API 已被移除。这是 Flutter 首次移除已弃用的 API,其中一些弃用甚至早于我们的迁移指南策略。

所有受影响的 API 已编译到此主要来源,以帮助迁移。还提供了一个快速参考表

设计文档文章 提供了有关 Flutter 弃用策略的更多上下文信息。

变更

#

本节列出了按受影响类列出的弃用项。

CupertinoDialog

#

修复工具支持:仅 IDE 修复。

CupertinoDialog 在 v0.2.3 中已弃用。请改用 CupertinoAlertDialogCupertinoPopupSurface

迁移指南

CupertinoAlertDialog

迁移前的代码:

dart
CupertinoDialog(child: myWidget);

迁移后的代码:

dart
CupertinoAlertDialog(content: myWidget);

CupertinoPopupSurface

迁移前的代码:

dart
CupertinoDialog(child: myWidget);

迁移后的代码:

dart
CupertinoPopupSurface(child: myWidget);

参考

API 文档:

相关问题:

相关 PR:


Cupertino 导航栏的 actionsForegroundColor

#

修复工具支持:否

CupertinoNavigationBar.actionsForegroundColorCupertinoSliverNavigationBar.actionsForegroundColor 在 v1.1.2 中已弃用。设置 CupertinoTheme 中的 primaryColor 会替代此设置。要访问 primaryColor,请调用 CupertinoTheme.of(context).primaryColor

迁移指南

迁移前的代码:

dart
CupertinoNavigationBar(
  actionsForegroundColor: CupertinoColors.systemBlue,
);
CupertinoSliverNavigationBar(
  actionsForegroundColor: CupertinoColors.systemBlue,
);

迁移后的代码:

dart
CupertinoTheme(
  data: CupertinoThemeData(
    primaryColor: CupertinoColors.systemBlue
  ),
  child: ...
);

// 从 `CupertinoTheme` 访问颜色
CupertinoTheme.of(context).primaryColor;

参考

API 文档:

相关问题:

相关 PR:


CupertinoTextThemeData.brightness

#

修复工具支持:是

CupertinoTextThemeData.brightness 在 v1.10.14 中已弃用。此字段成员在弃用时已失效。此参数没有替代项,应移除引用。

迁移指南

迁移前的代码:

dart
const CupertinoTextThemeData themeData = CupertinoTextThemeData(brightness: Brightness.dark);
themeData.copyWith(brightness: Brightness.light);

迁移后的代码:

dart
const CupertinoTextThemeData themeData = CupertinoTextThemeData();
themeData.copyWith();

参考

API 文档:

相关问题:

相关 PR:


指针事件构造的 fromHoverEvent

#

修复工具支持:是

PointerEnterEventPointerExitEventfromHoverEvent 构造函数在 v1.4.3 中已弃用。应改用 fromMouseEvent 构造函数。

迁移指南

迁移前的代码:

dart
final PointerEnterEvent enterEvent = PointerEnterEvent.fromHoverEvent(PointerHoverEvent());
final PointerExitEvent exitEvent = PointerExitEvent.fromHoverEvent(PointerHoverEvent());

迁移后的代码:

dart
final PointerEnterEvent enterEvent = PointerEnterEvent.fromMouseEvent(PointerHoverEvent());
final PointerExitEvent exitEvent = PointerExitEvent.fromMouseEvent(PointerHoverEvent());

参考

API 文档:

相关问题:

相关 PR:


showDialog 使用 builder

#

修复工具支持:是

showDialogchild 参数在 v0.2.3 中已弃用。应改用 builder 参数。

迁移指南

迁移前的代码:

dart
showDialog(child: myWidget);

迁移后的代码:

dart
showDialog(builder: (context) => myWidget);

参考

API 文档:

相关问题:

相关 PR:


Scaffold.resizeToAvoidBottomPadding

#

修复工具支持:是

ScaffoldresizeToAvoidBottomPadding 参数在 v1.1.9 中已弃用。应改用 resizeToAvoidBottomInset 参数。

迁移指南

迁移前的代码:

dart
Scaffold(resizeToAvoidBottomPadding: true);

迁移后的代码:

dart
Scaffold(resizeToAvoidBottomInset: true);

参考

API 文档:

相关问题:

相关 PR:


ButtonTheme.bar

#

修复工具支持:否

ButtonThemebar 构造函数在 v1.9.1 中已弃用。对于 ButtonBar,可以使用 ButtonBarTheme,如果使用不特定于 ButtonBar,则可以使用 ButtonTheme 的其他构造函数。

按钮特定的主题设置也可通过 TextButtonThemeElevatedButtonThemeOutlinedButtonTheme 类实现,每个类分别对应相应的按钮类 TextButtonElevatedButtonOutlinedButton

迁移指南

迁移前的代码:

dart
ButtonTheme.bar(
  minWidth: 10.0,
  alignedDropdown: true,
  height: 40.0,
);

迁移后的代码(使用 ButtonTheme):

dart
ButtonTheme(
  minWidth: 10.0,
  alignedDropdown: true,
  height: 40.0,
);

迁移后的代码(使用 ButtonBarTheme):

dart
ButtonBarTheme(
  data: ButtonBarThemeData(
    buttonMinWidth: 10.0,
    buttonAlignedDropdown: true,
    buttonHeight: 40.0,
  )
);

参考

API 文档:

相关问题:

相关 PR:


InlineSpanTextSpanPlaceholderSpan

#

修复工具支持:否

为了能够将小部件内嵌到段落中(如图像),InlineSpanTextSpanPlaceholderSpan 中的以下方法已弃用。

迁移指南

迁移前的代码迁移后的代码
InlineSpan.textTextSpan.text
InlineSpan.childrenTextSpan.children
InlineSpan.visitTextSpanInlineSpan.visitChildren
InlineSpan.recognizerTextSpan.recognizer
InlineSpan.describeSemanticsInlineSpan.computeSemanticsInformation
PlaceholderSpan.visitTextSpanPlaceHolderSpan.visitChildren
TextSpan.visitTextSpanTextSpan.visitChildren

参考

API 文档:

相关问题:

相关 PR:


RenderView.scheduleInitialFrame

#

修复工具支持:否

为了防止启动画面过早关闭而导致黑屏,RenderView.scheduleInitialFrame 方法已弃用并移除。当调用 WidgetsFlutterBinding.ensureInitialized 时,就会发生这种情况。相反,请将对该方法的调用替换为 RenderView.prepareInitialFrame,然后是 RenderView.owner.requestVisualUpdate

迁移指南

迁移前的代码:

dart
scheduleInitialFrame();

迁移后的代码:

dart
prepareInitialFrame();
owner.requestVisualUpdate();

参考

API 文档:

相关问题:

相关 PR:


Layer.findAll

#

修复工具支持:否

为了统一 findfindAll 的实现,Layer.findAll 方法已弃用,并引入了 Layer.findAnnotations。要迁移受影响的代码,请改用 findAllAnnotations。此方法返回一个 AnnotationResult,其中包含 AnnotationResult.annotationsfindAll 的先前返回值。

迁移指南

迁移前的代码:

dart
findAll(offset);

迁移后的代码:

dart
findAllAnnotations(offset).annotations;

参考

API 文档:

相关问题:

相关 PR:


BinaryMessages

#

修复工具支持:否

BinaryMessages 类、其关联的静态方法和 defaultBinaryMessenger getter 已弃用并移除。defaultBinaryMessenger 实例已移至 ServicesBinding。这使得可以通过为测试创建 ServicesBinding 子类,在测试环境下注册不同的默认 BinaryMessenger。这样做允许您跟踪挂起的平台消息的数量,以用于同步目的。

迁移指南

迁移前的代码:迁移后的代码:
defaultBinaryMessengerServicesBinding.instance.defaultBinaryMessenger
BinaryMessagesBinaryMessenger
BinaryMessages.handlePlatformMessageServicesBinding.instance.defaultBinaryMessenger.handlePlatformMessage
BinaryMessages.sendServicesBinding.instance.defaultBinaryMessenger.send
BinaryMessages.setMessageHandlerServicesBinding.instance.defaultBinaryMessenger.setMessageHandler
BinaryMessages.setMockMessageHandlerServicesBinding.instance.defaultBinaryMessenger.setMockMessageHandler

参考

API 文档:

相关问题:

相关 PR:


BuildContext 的泛型方法

#

修复工具支持:是

BuildContext 中的几种方法使用 Type 来搜索祖先。大多数这些方法在调用站点隐含强制类型转换,因为它们的返回类型是父类型。此外,即使类型实际上受到约束,在分析时也不会检查提供的类型。将这些方法设为泛型可以提高类型安全性并减少代码量。

这些方法更改会影响 BuildContextElementStatefulElement 类。TypeMatcher 类也已移除。

迁移指南

迁移前的代码:

dart
ComplexLayoutState state = context.ancestorStateOfType(const TypeMatcher<ComplexLayoutState>()) as ComplexLayoutState;

迁移后的代码:

dart
ComplexLayoutState state = context.ancestorStateOfType<ComplexLayoutState>();

BuildContext

迁移前的代码:迁移后的代码:
inheritFromElementdependOnInheritedElement
inheritFromWidgetOfExactTypedependOnInheritedWidgetOfExactType
ancestorInheritedElementForWidgetOfExactTypegetElementForInheritedWidgetOfExactType
ancestorWidgetOfExactTypefindAncestorWidgetOfExactType
ancestorStateOfTypefindAncestorStateOfType
rootAncestorStateOfTypefindRootAncestorStateOfType
ancestorRenderObjectOfTypefindAncestorRenderObjectOfType

Element

迁移前的代码:迁移后的代码:
inheritFromElementdependOnInheritedElement
inheritFromWidgetOfExactTypedependOnInheritedWidgetOfExactType
ancestorInheritedElementForWidgetOfExactTypegetElementForInheritedWidgetOfExactType
ancestorWidgetOfExactTypefindAncestorWidgetOfExactType
ancestorStateOfTypefindAncestorStateOfType
rootAncestorStateOfTypefindRootAncestorStateOfType
ancestorRenderObjectOfTypefindAncestorRenderObjectOfType

StatefulElement

迁移前的代码:迁移后的代码:
inheritFromElementdependOnInheritedElement

参考

API 文档:

相关 PR:


WidgetsBinding.deferFirstFrameReport & WidgetsBinding.allowFirstFrameReport

#

修复工具支持:是

deferFirstFrameReportallowFirstFrameReport 方法

为了提供延迟渲染第一帧的选项,WidgetsBindingdeferFirstFrameReportallowFirstFrameReport 方法已被弃用并移除。这对于需要异步获取初始化信息的部件非常有用,并且在它们等待这些信息时,不应渲染任何帧,因为这会过早地关闭启动画面。应分别改用 deferFirstFrameallowFirstFrame 方法。

迁移指南

迁移前的代码:

dart
final WidgetsBinding binding = WidgetsBinding.instance;
binding.deferFirstFrameReport();
binding.allowFirstFrameReport();

迁移后的代码:

dart
final WidgetsBinding binding = WidgetsBinding.instance;
binding.deferFirstFrame();
binding.allowFirstFrame();

参考

API 文档:

相关 PR:


WaitUntilNoTransientCallbacksWaitUntilNoPendingFrameWaitUntilFirstFrameRasterized

#

修复工具支持:否

flutter_driver 包中的 WaitUntilNoTransientCallbacksWaitUntilNoPendingFrameWaitUntilFirstFrameRasterized 方法已被弃用并移除,以便提供更易组合的 waitForCondition API,该 API 可用于组合客户端想要等待的条件。

迁移指南

迁移前的代码:迁移后的代码:
WaitUntilNoTransientCallbacksWaitForCondition(NoTransientCallbacks())
WaitUntilNoPendingFrameWaitForCondition(NoPendingFrame())
WaitUntilFirstFrameRasterizedWaitForCondition(FirstFrameRasterized())

参考

API 文档:

相关问题:

相关 PR:


时间线

#

稳定版:2.0.0