【问题标题】:Dart Navigator gives NoSuchMethodErrorDart Navigator 给出 NoSuchMethodError
【发布时间】:2017-12-19 15:21:03
【问题描述】:

我需要帮助,我正在尝试在按下按钮时显示一个新页面。我收到以下错误:

I/flutter (31562): The following NoSuchMethodError was thrown while handling a gesture:
I/flutter (31562): Class 'MyHomePage' has no instance getter 'context'.
I/flutter (31562): Receiver: Instance of 'MyHomePage'
I/flutter (31562): Tried calling: context
I/flutter (31562): When the exception was thrown, this was the stack:

这是我的代码:

import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

class MyHomePage extends StatelessWidget{

  Container pictureSection(){
    return new Container(
      child: new Image.asset(
        'images/sw.jpeg',
        width: 600.0,
        height: 240.0,
        fit: BoxFit.cover,
      ),
    );
  }

  Container mainMenuSection(){
    var spacer = new SizedBox(height: 12.0);
    return new Container(
      child: new Column(
        children: <Widget>[
          spacer,
          new RaisedButton(
            onPressed: () {Navigator.of(context).pushNamed('/PlanetsPage');},
            child: new Text('Get Planet'),
            ),
          spacer,
          ],
        ),
      );
  }

  @override
  Widget build(BuildContext context){
    var spacer = new SizedBox(height: 32.0);
    var spacer2 = new SizedBox(height: 15.0);
    return new Scaffold(
      body: new Center(
        child: new Column(
          children: <Widget>[
            pictureSection(),
            mainMenuSection(),
          ],
        ),
      ),
    );
  }
}

class PlanetsPage extends StatelessWidget{
  Widget build(BuildContext context){
    return new Scaffold(
      body: new Center(
        child: new Column(
          child: new Text('Hello World'),
        ),
      ),
    );
  }
}

void main(){
  runApp(new MaterialApp(
    home: new MyHomePage(),
    routes: <String, WidgetBuilder> {
      '/PlanetsPage': (BuildContext context) => new PlanetsPage(),
    },
  ));
}

按下按钮时,我正试图从主页转到行星页面,并且只有在按下按钮时才会出现错误。我正在使用我的 Hauwei Nova 进行测试。

【问题讨论】:

    标签: android sdk dart flutter


    【解决方案1】:

    尝试从build 方法传递BuildContext,而不是使用MyHomePagecontext 成员。见下文:

    import 'dart:convert';
    import 'package:flutter/material.dart';
    import 'package:flutter/services.dart';
    
    class MyHomePage extends StatelessWidget{
    
      Container pictureSection(){
        return new Container(
          child: new Image.asset(
            'images/sw.jpeg',
            width: 600.0,
            height: 240.0,
            fit: BoxFit.cover,
          ),
        );
      }
    
      Container mainMenuSection(BuildContext context){
        var spacer = new SizedBox(height: 12.0);
        return new Container(
          child: new Column(
            children: <Widget>[
              spacer,
              new RaisedButton(
                onPressed: () {Navigator.of(context).pushNamed('/PlanetsPage');},
                child: new Text('Get Planet'),
                ),
              spacer,
              ],
            ),
          );
      }
    
      @override
      Widget build(BuildContext context){
        var spacer = new SizedBox(height: 32.0);
        var spacer2 = new SizedBox(height: 15.0);
        return new Scaffold(
          body: new Center(
            child: new Column(
              children: <Widget>[
                pictureSection(),
                mainMenuSection(context),
              ],
            ),
          ),
        );
      }
    }
    
    class PlanetsPage extends StatelessWidget{
      Widget build(BuildContext context){
        return new Scaffold(
          body: new Center(
            child: new Column(
              child: new Text('Hello World'),
            ),
          ),
        );
      }
    }
    
    void main(){
      runApp(new MaterialApp(
        home: new MyHomePage(),
        routes: <String, WidgetBuilder> {
          '/PlanetsPage': (BuildContext context) => new PlanetsPage(),
        },
      ));
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-08-17
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-01-29
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多