chi*_*chi 3 flutter getx flutter-getx
我正在List of Cards根据toDoId的数量创建。
toDoController.toDo() 就像
toDo = [q1, r4, g4, d4].obs;
Run Code Online (Sandbox Code Playgroud)
而且,这是我的 ListView.builder()
Obx(() {
List _todo = toDoController.toDo();
return ListView.builder(
shrinkWrap: true,
scrollDirection: Axis.horizontal,
itemCount: _todo.length,
itemBuilder: (BuildContext context, int i) {
var _loading = true;
var _title = 'loading';
getTodoInfo() async {
_title = await toDoController
.getTodoInfo(
_todo[i]
);
_loading = false;
print(_title); // 'Clean!' <--- returns correct title
}
getTodoInfo();
return Container(
height: 150,
width: 150,
child: _loading
? Text(
_title,
)
: Text(
_title,
),
);
},
);
})
Run Code Online (Sandbox Code Playgroud)
我试图让每个 Container 调用http requests以从我的数据库中获取标题。获取标题,然后更新到Text()下面的小部件。但是,从服务器返回值后,它不会更新。
我可以让他们使用FutureBuilder. 我也尝试过 FutureBuilder。但是,FutureBuilder 也不会对这些variable变化做出反应。所以,我试图在这里做到这一点。我有点明白了。之后,widget 返回了,是不是不可更改?有什么办法可以用 GetX 做到这一点吗?
Bak*_*ker 13
这是将 GetX 与 Listview.builder 结合使用的示例。
此示例使用 GetBuilder 而不是 Obx,因为我不确定使用流会增加任何好处。如果由于某种原因需要 observables/streams,numbers可以更新为 an.obs并且update()调用应该被删除并GetBuilder替换为GetXor Obx。如果有人问,我会将其添加为替代示例。
GetBuilder 包装了 ListView.builder 并且只会重建 ListView,而不是整个小部件树/页面。
import 'package:flutter/material.dart';
import 'package:get/get.dart';
class ListDataX extends GetxController {
List<int> numbers = List<int>.from([0,1,2,3]);
void httpCall() async {
await Future.delayed(Duration(seconds: 1),
() => numbers.add(numbers.last + 1)
);
update();
}
void reset() {
numbers = numbers.sublist(0, 3);
update();
}
}
class GetXListviewPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
ListDataX dx = Get.put(ListDataX());
print('Page ** rebuilt');
return Scaffold(
body: SafeArea(
child: Column(
children: [
Expanded(
flex: 8,
child: GetBuilder<ListDataX>(
builder: (_dx) => ListView.builder(
itemCount: _dx.numbers.length,
itemBuilder: (context, index) {
return ListTile(
title: Text('Number: ${_dx.numbers[index]}'),
);
}),
),
),
Expanded(
flex: 1,
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
RaisedButton(
child: Text('Http Request'),
onPressed: dx.httpCall,
),
RaisedButton(
child: Text('Reset'),
onPressed: dx.reset,
)
],
)
)
],
),
),
);
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4948 次 |
| 最近记录: |