Flutter:提供程序错误如何添加新页面
抱歉,这是我第一次使用提供商 我不知道如何让按钮将我带到另一个页面 我制作了一个带有过滤器的网页 主屏幕
Scaffold(
key: context.read<MenuController>().scaffoldKey,
drawer: DrawerView(),
body: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
if (Responsive.isDesktop(context))
Expanded(
flex: 2,
// default flex = 1
// and it takes 1/6 part of the screen
child: DrawerView(),
),
// We want this side menu only for large screen
Expanded(
// It takes 5/6 part of the screen
flex: 8,
child: DashboardScreen(),
),
],
),
);
该页面分为三个部分 提供程序部分、仪表板部分和统计信息部分
菜单控制器
class MenuController extends ChangeNotifier {
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
GlobalKey<ScaffoldState> get scaffoldKey => _scaffoldKey;
void controlMenu() {
if (!_scaffoldKey.currentState!.isDrawerOpen) {
_scaffoldKey.currentState!.openDrawer();
}
}
}
main.dart
home: MultiProvider(
providers: [
ChangeNotifierProvider(
create: (context) => MenuController(),
),
],
child: MainScreen(),
),
错误:无法在此 MainScreen Widget 上方找到正确的提供程序
发生这种情况是因为您使用了不包含提供程序的 BuildContext
由您选择。有一些常见的场景:
- 您在
main.dart
中添加了一个新的提供程序并执行了热重载。 要修复,请执行热重启。
Sorry, this is my first time using a provider
I don't know how to make the button take me to another page
I made a web page with filters
Main Screen
Scaffold(
key: context.read<MenuController>().scaffoldKey,
drawer: DrawerView(),
body: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
if (Responsive.isDesktop(context))
Expanded(
flex: 2,
// default flex = 1
// and it takes 1/6 part of the screen
child: DrawerView(),
),
// We want this side menu only for large screen
Expanded(
// It takes 5/6 part of the screen
flex: 8,
child: DashboardScreen(),
),
],
),
);
The page is divided into three parts
The provider part, the dashboard part, and the stats part
Menu Controller
class MenuController extends ChangeNotifier {
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
GlobalKey<ScaffoldState> get scaffoldKey => _scaffoldKey;
void controlMenu() {
if (!_scaffoldKey.currentState!.isDrawerOpen) {
_scaffoldKey.currentState!.openDrawer();
}
}
}
main.dart
home: MultiProvider(
providers: [
ChangeNotifierProvider(
create: (context) => MenuController(),
),
],
child: MainScreen(),
),
Error: Could not find the correct Provider above this MainScreen Widget
This happens because you used a BuildContext
that does not include the provider
of your choice. There are a few common scenarios:
- You added a new provider in your
main.dart
and performed a hot-reload.
To fix, perform a hot-restart.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
声明&实施如下提供者
Declare & implement provider like below