我有以下设置:
MaterialApp(home:SplashScreen) SplashScreen( ///do some auth checks then Navigator.of(context).push( MaterialPageRoute( builder: (_) => StateInheritedWidget( user: userData, child: HomePage(), ))) )
然后在我HomePage的FAB中,我推了一条新路线。这条新路线无法访问我继承的窗口小部件的上下文。
HomePage
是不可能InheritedWidget在新的路线中获得上下文的,还是有解决此问题的方法?
InheritedWidget
更新资料
这是我的MaterialApp的构建器属性
builder: (context,child){ ///Doing some auth stuff here return new StateInheritedWidget( user: userData, child: userData==null?const SplashScreen(child: const LoginPage(),): const SplashScreen(child: const HomePage(),), ); },
我的SplashScreen构建方法:
SplashScreen
return !_load? new Scaffold( body: new Center( child: new Text('Splash'), ), ):this.widget.child;
这些是我得到的错误。
第一个似乎与Drawer我的中的有关HomePage:
Drawer
I/flutter (12688): ══╡ EXCEPTION CAUGHT BY WIDGETS LIBRARY ╞═══════════════════════════════════════════════════════════ I/flutter (12688): The following assertion was thrown building Tooltip("Open navigation menu", vertical offset: 24.0, I/flutter (12688): position: below, dirty, state: _TooltipState#44ae9(ticker inactive)): I/flutter (12688): No Overlay widget found. I/flutter (12688): Tooltip widgets require an Overlay widget ancestor for correct operation. I/flutter (12688): The most common way to add an Overlay to an application is to include a MaterialApp or Navigator I/flutter (12688): widget in the runApp() call. I/flutter (12688): The specific widget that failed to find an overlay was: I/flutter (12688): Tooltip("Open navigation menu", vertical offset: 24.0, position: below) I/flutter (12688):
当我单击FAB(Navigator.push)时出现第二个异常
I/flutter (12688): Another exception was thrown: Navigator operation requested with a context that does not include a Navigator.
不行。这是不可能的(或至少不建议这样做)。
问题在于您的InheritedWidget不应位于路线 内 ,而应位于路线 上方 。通常在上面MaterialApp
MaterialApp
但是我希望我的身份验证能够推送登录屏幕,我不能放在上面MaterialApp!
这就是为什么我说usually。:D
usually
身份验证是这些例外之一。您可能希望身份验证层访问导航器。但是仍然要与 所有 路由共享该身份验证层。
这是使用的有用属性的地方MaterialApp:builder
builder
通过Builder时,将用于在路线上方插入任何类型的小部件。但仍要紧追其后,Navigator以便您仍然可以在需要时推新路线。
Navigator
最后,您将拥有
new MaterialApp( builder: (context, child) { return new MyAuthent(child: child); }, ... // home: SplashSceen ? );
这很可能需要您进行重构。但这是实现此目标的正确方法。