Как решить проблему Значок панели инструментов нажал для навигации

Я пытаюсь разработать приложение флаттера. В этом приложении я использовал панель приложений со значком пользователя для перехода на другую страницу.

Теперь я нажал, что значок (значок человека) показывает ошибку.

,

Он не имеет надлежащей документации, хотя интернет. Я не мог найти ответ. Мой исходный код

class MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
        home: new Scaffold(
            appBar: new AppBar(
              title: new Text("Web Issue finder"),
              actions: <Widget>[
                new IconButton(
                  icon: Icon(Icons.person),
//                  tooltip: "Admin",
                  onPressed: (){
                    Navigator.push(
                      context,
                      MaterialPageRoute(builder: (_) => AdminAuth()),
                    );
                  }
                )
              ],
            ),
            body: new FutureBuilder(
                future: loadStates(),
                builder: (context, snapshot) {
                  if (snapshot.hasData) {
                    return new ListView.builder(
                      itemBuilder: (context, index) {
                        if (index >= snapshot?.data?.length ?? 0) return null;

                        return new ListTile(
                          title: new Text("${snapshot.data[index]}"),
                          onTap: () {
                            debugPrint("${snapshot.data[index]} clicked");
                            Navigator.push(
                              context,
                              MaterialPageRoute(
                                builder: (context) =>
                                    IssueAddScreen(state: snapshot.data[index]),
                              ),
                            );
                          },
                        );
                      },
                    );
                  } else {
                    return new Center(child: new CircularProgressIndicator());
                  }
                })));
  }

это пройденный класс

import 'package:flutter/material.dart';


class AdminAuth extends StatelessWidget{

//  final String state;

//  IssueAddScreen({Key key, @required this.state}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      title: "iWallet",
      home: Scaffold(
        appBar: AppBar(title: Text("admin auth"),),
        body: Text("cvgbh"),
      ),

    );
  }

}

Тем не менее, я не могу исправить эту ошибку, я следую за некоторыми документами и вопросами переполнения стека.

флаттер документация

Github вопрос и ответ

Stackru вопрос и ответ

2 ответа

IconButton(onPressed: () {
           Navigator.of(context).push(new MaterialPageRoute(builder: (context)=> AdminAuth));
        },)

Есть некоторая проблема с контекстом MateriaApp в библиотеке. Ваш код не будет работать. Создайте другой MaterialApp, а затем используйте свой виджет в свойстве home: MaterialApp.

Например:

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        primarySwatch: Colors.lightBlue,
      ),
      home: MyAppState(), //This is your MyAppState
    );
  }
}

Теперь вы можете удалить виджет MaterialApp в MyAppState, оставив только виджет Scaffold.

Попробуйте использовать контекст в вашем сборщике

Navigator.push(context,MaterialPageRoute(builder: (BuildContext context){return AdminAuth();
});

Проблема здесь в том, что Navigator отсутствует в родительском контексте. Вы используете контекст для MyApp, который не находится под навигатором.

MyApp    <------ context
  --> MaterialApp
   (--> Navigator built within MaterialApp)
      --> Scaffold
        --> App Bar
          --> ...

решить эту проблему - определить новый класс, содержащий MaterialApp затем пройти MyApp() в home: из MaterialApp,

То же самое для AdminAuth,

class MyAppHome extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: MyApp(),
    );
  }
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}


class _MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: new AppBar(
          title: new Text("Web Issue finder"),
          actions: <Widget>[
            new IconButton(
                icon: Icon(Icons.person),
//                  tooltip: "Admin",
                onPressed: () {
                  Navigator.push(
                    context,
                    MaterialPageRoute(builder: (_) => AdminAuth()),
                  );
                })
          ],
        ),
        body: new FutureBuilder(
            future: loadStates(),
            builder: (context, snapshot) {
              if (snapshot.hasData) {
                return new ListView.builder(
                  itemBuilder: (context, index) {
                    if (index >= snapshot?.data?.length ?? 0) return null;

                    return new ListTile(
                      title: new Text("${snapshot.data[index]}"),
                      onTap: () {
                        debugPrint("${snapshot.data[index]} clicked");
                        Navigator.push(
                          context,
                          MaterialPageRoute(
                            builder: (context) =>
                                IssueAddScreen(state: snapshot.data[index]),
                          ),
                        );
                      },
                    );
                  },
                );
              } else {
                return new Center(child: new CircularProgressIndicator());
              }
            }));
  }
}

Проблема в том, что объяснено выше. Мои собственные слова: контекст, из которого вы вызываете "Навигатор", не содержит "Навигатора". Я предполагаю, что проблема в том, что в вашем коде вы вызываете Scaffold до того, как MaterialApp завершит метод сборки и получит навигатор или что-то в этом роде. Если вы разделите MaterialApp и Scaffold (как показано ниже), вы решите проблему.

void main() => runApp(MaterialApp(
    home: MyApp())


class MyAppState extends State<MyApp> {
@override
Widget build(BuildContext context) {
return new Scaffold(
        appBar: new AppBar(
          title: new Text("Web Issue finder"),
          actions: <Widget>[
            new IconButton(
              icon: Icon(Icons.person),
            tooltip: "Admin",
              onPressed: (){
                Navigator.push(
                  context,
                  MaterialPageRoute(builder: (_) => AdminAuth()),
                );
              }
            )
          ],
        ),
        body: new FutureBuilder(
            future: loadStates(),
            builder: (context, snapshot) {
              if (snapshot.hasData) {
                return new ListView.builder(
                  itemBuilder: (context, index) {
                    if (index >= snapshot?.data?.length ?? 0) return null;

                    return new ListTile(
                      title: new Text("${snapshot.data[index]}"),
                      onTap: () {
                        debugPrint("${snapshot.data[index]} clicked");
                        Navigator.push(
                          context,
                          MaterialPageRoute(
                            builder: (context) =>
                                IssueAddScreen(state: snapshot.data[index]),
                          ),
                        );
                      },
                    );
                  },
                );
              } else {
                return new Center(child: new CircularProgressIndicator());
              }
            })));
Другие вопросы по тегам