как это работает? или где можно почитаь про разницу между просто BuildContext и .of(BuildContext)? для меня непонятно, как для уже пропавшего контекста (да, который когда-то существовал, но сейчас он !mounted) можно спокойно показывать snackBar. showSnackbar ведь вызывается для SnackbarMessageState, который был создан в контексте, который уже не актуален
*приведенный код позволяет показывать Snackbar даже если context !mounted*
снэкбар показывается в скаффолд мессенджере. Через контекст вы его просто вытаскиваете, то, что потом контекст уже отмонтировался, значения не имеет, сам скаффолд менеджер на месте
а если про Navigator.of(context).push? то он делает пуш из навигатора, который просто когда-то был создан и это не приводит к каким-то ошибкам?
of(BuildContext) это exstension method над buildContext'ом
тут смысл в том, когда именно of вызывается. of грубо говоря означает - бери текущий элемент (контекст) и иди вверх по дереву, пока не найдешь элемент. После этого уже неважно, контекст монтирован или не , важно, чтобы найденный элемент еще на месте был. Но если в момент вызова of контекст будет отмонтирован, то и элемент найти не получится
в примере получаем ссылку на messenger, ожидаем и после показываем, context роли уже не играет, он нужен только чтобы получить messenger, в вашем случае, возможно, если что-то еще не поменяет состояние, подойдет
все верно, просто формально ScaffoldMessenger.of не шарится по дереву так как _ScaffoldMessengerScope - InheritedWidget поэтому здесь через dependOnInheritedWidgetOfExactType
да понятно, просто так объяснить проще
Обсуждают сегодня