Flutter提示之Navigator operation requested with a context that does not include a Navigator.

1 、问题

用Flutter写了页面跳转,提示错误如下

Navigator operation requested with a context that does not include a Navigator.

 

 

 

 

 

 

 

 

 

 

2 、我的代码

void main() {
  runApp(MyApp1());
}


class MyApp1 extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'open url',home: Scaffold(
          appBar: AppBar(
            title: Text('hello flutter'),),body: Column(
            mainAxisAlignment: MainAxisAlignment.center,mainAxisSize: MainAxisSize.min,children: <Widget>[
              FlatButton(
                child: Text("go to new page"),textColor: Colors.blue,onPressed: () {
                    Navigator.push(context,MaterialPageRoute(
                      builder:(context) => NewPage()));
                },],);
  }
}


class NewPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
      return Scaffold(
        appBar: AppBar(
            title: Text("hello word"),body: Center(
           child: Text("this is new page"),);
  }
}

 

 

 

 

 

 

 

 

 

 

 

 

 

3、原因

Navigator operation requested with a context that does not include a Navigator.

说明这个context上下文不一致,我们看下Navigator的继承关系

class Navigator extends StatefulWidget {
}

但是我的代码是这样的

class MyApp1 extends StatelessWidget {
}

我们需要使用StatefulWidget的Context


 

 

 

 

 

 

 

 

 

 

 

4、解决办法

void main() {
    runApp(MaterialApp(
    title: "Navigation basics",home: MyApp1(),));
}

用MaterialApp启动

class MaterialApp extends StatefulWidget {
***
}

 

相关文章

这篇文章主要讲解了“FlutterComponent动画的显和隐怎么实现...
这篇文章主要讲解了“flutter微信聊天输入框功能如何实现”,...
本篇内容介绍了“Flutter之Navigator的高级用法有哪些”的有...
这篇文章主要介绍“Flutter怎么使用Android原生播放器”,在...
Flutter开发的android端如何修改APP名称,logo,版本号,具体...
Flutter路由管理初识路由概念一.路由管理1.1.Route1.2.Mater...