0

我的导航栏有问题。每当我单击导航栏中的管理下拉菜单时,错误

使用不包含 Navigator 的上下文请求的 Navigator 操作。

在此处输入图像描述

主要.dart

MyStyledToast(
    child: BlocBuilder<AuthBloc, AuthState>(
      builder: (context, state) {
        return MaterialApp(
          title: 'CRM',
          debugShowCheckedModeBanner: false,
          builder: (context, child) => LayoutTemplate(child: child),
          navigatorKey: locator<NavigationService>().navigatorKey,
          onGenerateRoute: generateRoute,
          initialRoute:
              (state is AuthenticatedState) ? UsersRoute : LoginRoute,
          theme: themeData,
        );
      },
    ),
  ),

nav_bar.dart

Container(
  height: 60,
  decoration: BoxDecoration(
    color: Colors.white,
    boxShadow: [
      BoxShadow(
        color: Colors.grey.withOpacity(0.5),
        spreadRadius: 2,
        blurRadius: 8,
        offset: Offset(0, -4), // changes position of shadow
      ),
    ],
  ),
  padding: EdgeInsets.symmetric(horizontal: 20),
  child: Row(
    crossAxisAlignment: CrossAxisAlignment.center,
    mainAxisAlignment: MainAxisAlignment.spaceBetween,
    children: <Widget>[
      Row(
        mainAxisSize: MainAxisSize.min,
        children: <Widget>[
          NavBarLogo(),
          SizedBox(
            width: 80,
          ),
          NavBarItem('Home', HomeRoute),
          SizedBox(
            width: 40,
          ),
          NavBarItem('Customers', CustomersRoute),
          SizedBox(
            width: 40,
          ),
          NavBarItem('Tickets', TicketsRoute),
          SizedBox(
            width: 40,
          ),
          NavBarItem('Reports', ReportsRoute),
          SizedBox(
            width: 40,
          ),
          NavBarItem('Dashboard', DashboardRoute),
          SizedBox(
            width: 40,
          ),
          DropdownButtonHideUnderline(
            child: DropdownButton<String>(
              iconSize: 24,
              elevation: 16,
              hint: Text(
                'Admin',
                style: Theme.of(context).textTheme.headline1,
              ),
              style: Theme.of(context).textTheme.headline1,
              onChanged: (String newValue) {
                if (newValue == 'Users') {
                  context.read<UserBloc>().add(LoadDataEvent());
                  locator<NavigationService>()
                      .navigateReplaceTo(UsersRoute);
                } else if (newValue == 'Roles') {
                  locator<NavigationService>()
                      .navigateReplaceTo(RolesRoute);
                }
              },
              items: <String>[
                'Users',
                'Roles',
              ].map<DropdownMenuItem<String>>((String value) {
                return DropdownMenuItem<String>(
                  value: value,
                  child: Text(value),
                );
              }).toList(),
            ),
          ),
        ],
      ),
      Row(
        children: [
          NavBarIcon(Icons.notifications_none, HomeRoute),
          SizedBox(
            width: 5,
          ),
          NavBarIcon(Icons.person_outline, ProfileRoute),
        ],
      ),
    ],
  ),
);

导航服务.dart

class NavigationService {
 final GlobalKey<NavigatorState> navigatorKey = GlobalKey<NavigatorState>();

 Future<dynamic> navigateTo(String routeName) {
  return navigatorKey.currentState.pushNamed(routeName);
 }

 Future<dynamic> navigateReplaceTo(String routeName) {
  return navigatorKey.currentState.pushReplacementNamed(routeName);
 }

 Future<dynamic> navigateReplaceAllTo(String routeName) {
   return navigatorKey.currentState
    .pushNamedAndRemoveUntil(routeName, (route) => false);
 }

 void goBack() {
   return navigatorKey.currentState.pop();
 }

 void popDialog(BuildContext context) {
   return Navigator.pop(context);
 }
}
4

0 回答 0