obx listView在价值更改后未更新
我有一个rxlist
称为tododata
。在此列表的基础上,listView.builder
构建一个列表,在每个列表中都有一个按钮。单击此按钮后,完成
相应项目的字段已更新为true
或false
。但是,尽管该值已更新,但UI却没有更改。
这是列表:
class StateController extends GetxController {
RxList<Todo> todoData = <Todo>[
Todo(
name: 'todo1',
done: true),
Todo(
name: 'todo2',
done: false),
Todo(
name: 'todo3',
done: true),
Todo(
name: 'todo4',
done: false),
Todo(
name: 'todo5',
done: false)
].obs;
}
控制器:
final StateController _controller = Get.find();
更新功能:
void updateItem(Todo e) {
/* final int index = _controller.todoData.indexOf(e);
_controller.todoData[index].done = !e.done; */
_controller.todoData.firstWhere((Todo i) => i == e).done = !e.done;
_controller.refresh();
}
void deleteItem(Todo e) { //**this works**
final int index = _controller.todoData.indexOf(e);
_controller.todoData.removeAt(index);
}
UI:
Obx(() => ListView.builder(
itemCount: _controller.todoData.length,
itemBuilder: (_, int i) => TodoItem(
item: _controller.todoData[i],
updateItem: () =>
updateItem(_controller.todoData[i]),
))
对任何帮助都非常感谢!
I am having a RxList
called todoData
. On the basis of this list, a ListView.builder
builds a list and in each list there is a button. When this button is clicked the done
field of the respective item is updated to either true
or false
. But, though the value is updated the ui is no changing.
Here's the list:
class StateController extends GetxController {
RxList<Todo> todoData = <Todo>[
Todo(
name: 'todo1',
done: true),
Todo(
name: 'todo2',
done: false),
Todo(
name: 'todo3',
done: true),
Todo(
name: 'todo4',
done: false),
Todo(
name: 'todo5',
done: false)
].obs;
}
Controller:
final StateController _controller = Get.find();
The update function:
void updateItem(Todo e) {
/* final int index = _controller.todoData.indexOf(e);
_controller.todoData[index].done = !e.done; */
_controller.todoData.firstWhere((Todo i) => i == e).done = !e.done;
_controller.refresh();
}
void deleteItem(Todo e) { //**this works**
final int index = _controller.todoData.indexOf(e);
_controller.todoData.removeAt(index);
}
Ui:
Obx(() => ListView.builder(
itemCount: _controller.todoData.length,
itemBuilder: (_, int i) => TodoItem(
item: _controller.todoData[i],
updateItem: () =>
updateItem(_controller.todoData[i]),
))
Any help is greatly appreciated!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
obx
仅对反应性(RX)变量进行的更改做出反应。您当前拥有的唯一反应性变量是rxlist
,因此只有对该列表进行的更改才会触发您的obx
更新。当您更改
完成
时,您正在更改todo
而不是列表中的值,因此不对UI进行更新。解决此问题的一种方法是在更改
完成
时强制列表中的更新,您可以通过refresh()
在rxlist refresh()
来执行此操作。 > :(还假设
e
是列表中包含的对象,您可以直接执行e.done =!e.done
)Obx
only reacts to changes made in reactive (Rx) variables. The only reactive variable you have currently is theRxList
, so only changes made to that list will trigger yourObx
to update.When you change
done
, you're changing a value inTodo
, not the list, so no update is made to the UI.One way to fix this is to force an update in the list when you change
done
, you can do this by callingrefresh()
on theRxList
:(Also, assuming
e
is the same object contained in the list, you can doe.done = !e.done
directly)我只是修改了您的一些代码,只需将rxlist更改为简单列表和bool变量,然后在bool上使用obx我共享代码
您的模型类和控制器类
您的UI代码
i just modify some code of yours, just change the RxList to simple List and bool variable to RxBool and use obx on bool I'm sharing code
Your Model class and controller class
your UI Code
您可以在这里做一些事情,以使您的代码按预期工作。
首先,您需要确保您的TODO类实现了可衡量的Mixin。这将使您可以按值而不是参考比较两个todo实例。
其次,您需要在rxList上使用update()方法来更新适当的托多实例的完成字段的值。
第三,您需要在更新完成的字段后在statecontroller上调用refresh()方法,以便更新UI以反映新值。
第四,您应该考虑使用脚步窗口小部件的内置updateItem()方法,而不是将回调转到窗口小部件。这将确保在更改完成字段时正确更新待遇小部件。
There are a few things you can do here to make your code work as expected.
First, you need to make sure that your Todo class implements the Equatable mixin. This will allow you to compare two Todo instances by value rather than by reference.
Second, you need to use the update() method on your RxList to update the value of the done field for the appropriate Todo instance.
Third, you need to call the refresh() method on your StateController after updating the done field so that the UI will be updated to reflect the new value.
Fourth, you should consider using the TodoItem widget's built-in updateItem() method rather than passing a callback to the widget. This will ensure that the TodoItem widget is updated correctly when the done field is changed.
中调用更新功能
尝试在OBX已经在构建过程中时,在更新 可能不会发生。 addpostframecallback 当前构建允许完成后,它将允许执行。要更新的UI。
Try Calling the Update Function inside
The update may not happen when Obx is already In process of Building. The addPostFrameCallback will execute after the current build has finished and it will allow the UI to be updated.