我正在尝试在父窗口小部件中初始化数据模型对象,但出现以下错误“只能在初始化器中访问静态成员”。我试图弄清楚如何解决这个问题。我还想知道这是否是在父窗口小部件中初始化数据模型的正确方法,或者是否有更好的方法可以做到这一点。
我有一个简单的TodoList模型,负责处理管理用户待办事项的所有逻辑。
class TodoList {
List<Todo> _items = [
Todo(
id: '1',
task: 'do laundry',
note: 'don\'t forget to seperate the whites')
];
List<Todo> get items {
return [..._items];
}
void toggleAll() {}
bool _hasIncompletedTodos() {
return _items.any((todo) => !todo.complete);
}
}
我不使用任何状态管理库,而只是将所有状态存储在根Widget(HomeScreen)中,并将所有状态传递给子Widget。
class _HomeScreenState extends State<HomeScreen> {
TodoList todoList;
int _selectedPageIndex = 0;
List<Map<String, dynamic>> _pages = [
{
'page': TodosListScreen(
todos: todoList.items, <<< Only static members can be accessed in initializers
),
'title': 'Todos'
},
{'page': TodosStatsScreen(), 'title': 'Stats'}
];
我看到了这篇文章,它建议将所有内容都移到initState中。我尝试这样做,但仍然出现相同的错误
Only static members can be accessed in initializer. Dart2.0
class _HomeScreenState extends State<HomeScreen> {
TodoList todoList;
int _selectedPageIndex = 0;
@override
void initState() {
super.initState();
todoList = TodoList();
}
List<Map<String, dynamic>> _pages = [
{
'page': TodosListScreen(
todos: todoList.items, <<<< same error
),
'title': 'Todos'
},
{'page': TodosStatsScreen(), 'title': 'Stats'}
];
答案 0 :(得分:1)
问题是当对象仍在构造中时,您正在引用该对象内部的对象。在Dart中创建对象分为两个阶段,首先我们要同时初始化所有数据,然后再调用构造函数主体。
这是您的问题所在:
class _HomeScreenState extends State<HomeScreen> {
TodoList todoList;
...
List<Map<String, dynamic>> _pages = [
{
'page': TodosListScreen(
todos: todoList.items, <<<< same error
),
'title': 'Todos'
},
{'page': TodosStatsScreen(), 'title': 'Stats'}
];
您的类_HomeScreenState
包含一个名为todoList
的变量,但是同时您在初始化_pages
变量时引用了此变量。但是因为我们仍处于初始化阶段,所以看不到todoList
变量。
您的代码也没有多大意义,因为即使这行得通,您也会得到空指针异常,因为todoList
试图访问null
时_pages
是todoList.items
_pages
的值。
我认为,最适合您的解决方案是将initState()
变量设置为build()
的一部分或像{ThidaSweZin所说的那样在queryGateway.subscriptionQuery(
FetchListOfBookQuery,
ResponseTypes.multipleInstancesOf(Book::class.java),
ResponseTypes.multipleInstancesOf(Book::class.java)
)
中设置。
答案 1 :(得分:0)
尝试如下操作,在小部件 build 方法中初始化。
List<Map<String, dynamic>> _pages;
@override
Widget build(BuildContext context) {
_pages = [
{
'page': TodosListScreen(
todos: todoList.items,
),
'title': 'Todos'
},
{'page': TodosStatsScreen(), 'title': 'Stats'}
];
}