restorablePush<T extends Object?> method
Null safety
- BuildContext context,
- RestorableRouteBuilder<
T> routeBuilder, - {Object? arguments}
Push a new route onto the navigator that most tightly encloses the given context.
Unlike Routes pushed via push, Routes pushed with this method are restored during state restoration according to the rules outlined in the "State Restoration" section of Navigator.
The new route and the previous route (if any) are notified (see Route.didPush and Route.didChangeNext). If the Navigator has any Navigator.observers, they will be notified as well (see NavigatorObserver.didPush).
Ongoing gestures within the current route are canceled when a new route is pushed.
The T
type argument is the type of the return value of the route.
The method takes a static RestorableRouteBuilder as argument, which
must instantiate and return a new Route object that will be added to
the navigator. The provided arguments
object is passed to the
routeBuilder
. The navigator calls the static routeBuilder
function
again during state restoration to re-create the route object.
Any object that is serializable via the StandardMessageCodec can be
passed as arguments
. Often, a Map is used to pass key-value pairs.
The method returns an opaque ID for the pushed route that can be used by the RestorableRouteFuture to gain access to the actual Route object added to the navigator and its return value. You can ignore the return value of this method, if you do not care about the route object or the route's return value.
flutter create --sample=widgets.Navigator.restorablePush.1 mysample
Implementation
@optionalTypeArgs
static String restorablePush<T extends Object?>(BuildContext context, RestorableRouteBuilder<T> routeBuilder, {Object? arguments}) {
return Navigator.of(context).restorablePush(routeBuilder, arguments: arguments);
}