popAndPushNamed< T extends Object, TO extends Object> method
- @optionalTypeArgs
Pop the current route off the navigator that most tightly encloses the given context and push a named route in its place.
If non-null, result
will be used as the result of the route that is
popped; the future that had been returned from pushing the popped route
will complete with result
. Routes such as dialogs or popup menus
typically use this mechanism to return the value selected by the user to
the widget that created their route. The type of result
, if provided,
must match the type argument of the class of the popped route (TO
).
The route name will be passed to the navigator's onGenerateRoute callback. The returned route will be pushed into the navigator.
The new route, the old route, and the route below the old route (if any)
are all notified (see Route.didPop, Route.didComplete,
Route.didPopNext, Route.didPush, and Route.didChangeNext). If the
Navigator has any Navigator.observers, they will be notified as well
(see NavigatorObserver.didPop and NavigatorObservers.didPush
). The
animations for the pop and the push are performed simultaneously, so the
route below may be briefly visible even if both the old route and the new
route are opaque (see TransitionRoute.opaque).
Ongoing gestures within the current route are canceled when a new route is pushed.
Returns a Future that completes to the result
value passed to pop
when the pushed route is popped off the navigator.
The T
type argument is the type of the return value of the new route,
and TO
is the return value type of the old route.
void _selectNewYork() {
Navigator.popAndPushNamed(context, '/nyc/1776');
}
Implementation
@optionalTypeArgs
static Future<T> popAndPushNamed<T extends Object, TO extends Object>(BuildContext context, String routeName, { TO result }) {
return Navigator.of(context).popAndPushNamed<T, TO>(routeName, result: result);
}