![](/img/trans.png)
[英]The Argument type 'Context' can't be assigned to the parameter type 'BuildContext' - Flutter
[英]Flutter Navigator “argument type 'Context' can't be assigned to the parameter type 'BuildContext'”
我试图将我的 menuButton 类别名称传递到下一页,并在我的 categoryScreens 上设置下一页的状态。
目前我收到一条红色波浪线,上面写着“无法将参数类型‘Context’分配给参数类型‘BuildContext’”
import 'package:flutter/material.dart';
import 'package:boardwalk/Screens/categoryScreen.dart';
import 'package:boardwalk/Widgets/headerCategory.dart';
import 'package:path/path.dart';
class homeMenu extends StatelessWidget {
const homeMenu({Key key}) : super(key: key);
Padding menuButton(String category, IconData categoryIcon) {
return Padding(
padding: const EdgeInsets.symmetric(horizontal: 10),
child: Container(
width: 95,
child: InkWell(
onTap: ()=>
Navigator.of(context).push(MaterialPageRoute(builder: (context) => categoryScreen()));
,
child: Column(
children: <Widget>[
Center(
child: Container(
height: 70,
width: 70,
decoration: BoxDecoration(
gradient: LinearGradient(
colors: [Colors.deepPurple, Colors.deepPurpleAccent],
),
shape: BoxShape.circle,
),
child: Icon(
categoryIcon,
size: 40.0,
color: Colors.white,
),
),
),
Padding(
padding: const EdgeInsets.all(6.0),
child: Text(
category,
style: TextStyle(
color: Colors.deepPurpleAccent,
fontSize: 14,
),
),
)
],
),
),
));
}
@override
Widget build(BuildContext context) {
return Padding(
padding: const EdgeInsets.only(top: 8.0),
child: Container(
height: 100,
width: 400,
child: ListView(scrollDirection: Axis.horizontal, children: <Widget>[
menuButton('Home', Icons.home),
menuButton('Eat', Icons.restaurant_menu),
menuButton('Shop', Icons.store),
menuButton('Travel', Icons.airplanemode_active),
menuButton('Play', Icons.local_activity),
menuButton('Service', Icons.build),
]),
),
);
}
}
如果导航器不喜欢上下文,我不确定在导航器中传递什么,我完全不确定此时会发生什么。
实际上,问题是由导入 path.dart 包引起的。 要解决此问题,请将上下文更改为 this.context
我只是将上下文更改为 this.context 并在寻找解决方案 2 小时后解决了问题!
Widget 无权访问build
方法之外的BuildContext
。 如果您正在创建一个可重用的 Widget 函数,例如这里的menuButton
,那么您必须传入您在build
方法中收到的BuildContext
实例。
所以你的代码变成,
class homeMenu extends StatelessWidget {
const homeMenu({Key key}) : super(key: key);
Padding menuButton(BuildContext context, String category, IconData categoryIcon, BuildContext context) {
return Padding(
padding: const EdgeInsets.symmetric(horizontal: 10),
...
);
}
@override
Widget build(BuildContext context) {
return Padding(
padding: const EdgeInsets.only(top: 8.0),
child: Container(
height: 100,
width: 400,
child: ListView(scrollDirection: Axis.horizontal, children: <Widget>[
menuButton(context, 'Home', Icons.home),
...
]),
),
);
}
}
如果“导入包”没有帮助,则意味着您应该尝试以下语句。
声明BuildContext 上下文; 这是一个参数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.