flutter – 使用Scaffold作为子项的InheritedWidget似乎不起作用

前端之家收集整理的这篇文章主要介绍了flutter – 使用Scaffold作为子项的InheritedWidget似乎不起作用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我希望在我的Flutter应用程序的根级别使用InheritedWidget,以确保所有子窗口小部件都可以使用经过身份验证的用户的详细信息.基本上让脚手架成为IW的孩子,就像这样:

@override
Widget build(BuildContext context) {
return new AuthenticatedWidget(
    user: _user,child: new Scaffold(
      appBar: new AppBar(
        title: 'My App',),body: new MyHome(),drawer: new MyDrawer(),));
}

这在app开始时按预期工作,所以表面看来我在AuthenticatedWidget中正确实现了InheritedWidget模式,但是当我从其他地方返回主页(MyHome)时:

Navigator.popAndPushNamed(context,'/home');

在MyHome的构建方法调用(之前有效)然后导致authWidget为null:

final authWidget = AuthenticatedWidget.of(context);

完全可能我错过了如何正确实现IW的一些细微差别,但同样,它确实最初工作,我也看到其他人提出同样的问题(即“继承的小部件”标题下的here).

因此,不能使用Scaffold或MaterialApp作为InheritedWidget的子级吗?或者这可能是一个提出的错误?提前致谢!

解决方法@H_301_31@
这是许多人在开始颤抖时难以理解的问题.

MyInherited.of(context)将基本上查看当前上下文的父级,以查看是否存在MyInherited实例化.

问题是:您继承的窗口小部件在当前上下文中实例化.

=>没有MyInherited作为父母

=>紧急

诀窍是使用不同的上下文.
那里有很多解决方案.您可以在另一个窗口小部件中实例化MyInherited,以便构建方法的上下文将MyInherited作为父窗口.

或者你可以使用Builder来引入一个虚假的小部件,它会传递给你它的上下文.

建造者的例子:

return new MyInheritedWidget(
  child: new Builder(
    builder: (context) => new Scaffold(),);

出于同样的原因,另一个问题是,如果在路由中插入inheritedWidget,它将不在此路由之外.

解决方案很简单!
将MyInheritedWidget放在MaterialApp上方.

以上材料:

new MyInherited(
  child: new MaterialApp(
    // ...
  ),)

猜你在找的Flutter相关文章