Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >更改子属性不会触发颤振Getx上的UI更改

更改子属性不会触发颤振Getx上的UI更改
EN

Stack Overflow用户
提问于 2020-10-06 06:31:54
回答 2查看 1.4K关注 0票数 2

我正在尝试基于对象列表呈现一个反应性小部件。

当该对象的子对象发生布尔属性更改时,应该更新UI。

在这个场景中,我的控制器有一个列表os节,每个部分都有一个教训列表。

为了更好地理解,我重新编写了我的代码,根据我需要的内容制作了一个简单的示例。我已经尝试使用.map、.forEach和其他方法,但是子属性从不触发UI更新。

代码语言:javascript
运行
AI代码解释
复制
GetX<LessonController>(
  initState: (state) => controller.getLessonsByCourse(course.id),
  builder: (_) {
    return Expanded(
      child: ListView.separated(
        scrollDirection: Axis.vertical,
        itemCount: _.sectionList.length,
        itemBuilder: (BuildContext context, int index) {
          return ExpansionTile(
              title: Text(_.sectionList[index].title),
              children: <Widget>[
                for(var i = 0; i < _.sectionList[index].lessons.length; i++)
                  Padding(
                    padding: const EdgeInsets.all(8.0),
                    child: 
                      Obx(() => 
                        GestureDetector(
                          child: Text((_.sectionList[index].lessons[i] as Lesson).isCompleted.toString()),
                          onTap: () {
                            (_.sectionList[index].lessons[i] as Lesson).isCompleted = !(_.sectionList[index].lessons[i]as Lesson).isCompleted;
                            print((_.sectionList[index].lessons[i]as Lesson).isCompleted.toString());
                          })
                      ),
                  )
              ]);
        },
        separatorBuilder: (context, ind) => Divider(
          height: 2,
          color: Colors.grey[300],
        ),
      ),
    );
  })

解决方案:

GetX容器监视列表项上的更改,因此当您从其中一个项更改属性时,列表本身不会更改。为了解决这个问题,我更改了item属性,然后我将它超编到列表中。

代码语言:javascript
运行
AI代码解释
复制
onTap: (value) {
    Section tappedSection = _.sectionList[index];
    tappedSection.lessons[lessonIndex].isCompleted = value;
    // This is the secret
    // Making GetX detect a change on the list and rebuild UI
    _.sectionList[index] = tappedSection;
}));
EN

回答 2

Stack Overflow用户

发布于 2020-10-08 05:57:40

据我所知,颤振GetX中的可观察列表与对象本身的内部更改无关。

为了强制UI更新,我必须将更新对象返回到列表中的相同位置,以便假装主列表中的对象发生了更改。

就像这样:

代码语言:javascript
运行
AI代码解释
复制
Section tappedSection = _.sectionList[index];
tappedSection.lessons[i].isCompleted = value;
_.notifyLessonProgress(tappedSection.lessons[i].id, value);
_.sectionList[index] = tappedSection;
票数 1
EN

Stack Overflow用户

发布于 2020-10-07 09:59:54

看起来问题就在这里:this._sectionList.value = value;

试一试:this._sectionList = value;

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64227960

复制
相关文章
【错误记录】Melodyne 报错 ( 无法打开音频文件 )
打开一个 48000Hz , 立体声音源 , 采样位数 32 位的采样 , 无法打开 , 报下面的错误 ;
韩曙亮
2023/03/29
9410
【错误记录】Melodyne 报错 ( 无法打开音频文件 )
office xls 文件已损坏 无法打开 word在试图打开文件时遇到错误
转自:http://windyli.blog.51cto.com/1300305/326491
全栈程序员站长
2022/09/01
2.7K0
【错误记录】无法打开 “xxx“ , 因为 Apple 无法检查其是否包含恶意软件
选择 " 通用 " 选项卡 , 在下面找到被拦截的软件 , 选择 " 仍要打开 " ;
韩曙亮
2023/03/29
1.2K0
【错误记录】无法打开 “xxx“ , 因为 Apple 无法检查其是否包含恶意软件
VS无法打开源文件及无法打开链接库文件的解决方法
依次点击“项目——配置属性——C/C++——常规”,在“附加包含目录”中加入.h文件所在的文件夹路径
全栈程序员站长
2022/09/08
6.6K0
VS无法打开源文件及无法打开链接库文件的解决方法
错误代码502,网页无法打开?教你如何解决!
在使用互联网的过程中,我们时常会遇到各种错误代码,其中502错误代码是最为常见的一种。502 Bad Gateway错误表示,网关或代理服务无法将请求发送到上游服务器。那么,错误代码502是什么意思?
德迅云安全--陈琦琦
2023/10/08
10.4K0
腾讯云香港服务器无法打开宝塔面板
toc 问题描述:腾讯云香港服务器无法打开宝塔面板 今天想试试香港服务器,看了下价格,心在滴血。。。 [在这里插入图片描述] 和国内的比也太贵了, 最后打算买一个月的试试水 [在这里插入图片描述] 安装了一下宝塔插件,finalshell可以正常连接服务器 [在这里插入图片描述] 测试一下连接百度 [在这里插入图片描述] 可是宝塔面板就是进不去 [在这里插入图片描述] 解决方法 登录服务器控制台,打开安全组 [在这里插入图片描述] 点击修改规则 [在这里插入图片描述] 在协议端口添加 ==,8888=
炒香菇的书呆子
2021/05/17
45.4K0
腾讯云香港服务器无法打开宝塔面板
SaveFileDialog无法打开
当前画面是报表画面,没用线程。主画面点击按钮,打开该画面,是在子线程中打开的,所以SaveFileDialog也无法直接打开
全栈程序员站长
2022/11/10
2K0
matlab中importdata无法打开文件_importdata无法打开文件
最近使用importdata函数不能读取全部数据,数据集315行,但是读取了197行,那就是197-198之间有问题,百度之后有了思路。由于没有找到具体的证据,所以这里说一下解决思路。
全栈程序员站长
2022/11/16
6.5K0
matlab中importdata无法打开文件_importdata无法打开文件
解决xampp无法打开数据库的问题
因为以前安装过mysql所以需要更改注册表路径 首先在c盘的C:\Windows路径下找到注册表编辑器,打开
天天Lotay
2022/12/02
1.6K0
解决xampp无法打开数据库的问题
错误 RC1015: 无法打开包含文件 'XTToolkitPro.rc'
XtremeToolkitPro作为VC++/MFC平台下目前最流行的GUI界面库之一,安装和使用都很方便。不过,在实际使用中还是碰到许多问题。如果在编译工程时只显示一个错误:RC1015: 无法打开包含文件 'XTToolkitPro.rc',这时可能是因为资源路径问题导致。解决方法有两种:
步行者08
2018/10/09
2.4K0
word输入矩阵卡死,导致word在试图打开文件时遇到错误
问题: 今天用office word 2019输入一个矩阵的时候,突然卡死了。强制关闭了word。再打开就变成这样了。
全栈程序员站长
2022/08/31
1.2K0
香港服务器无法打开宝塔面板解决方法
@toc 问题描述:腾讯云香港服务器无法打开宝塔面板 今天想试试香港服务器,看了下价格,心在滴血。。。 [在这里插入图片描述] 和国内的比也太贵了, 最后打算买一个月的试试水 [在这里插入图片描述] 安装了一下宝塔插件,finalshell可以正常连接服务器 [在这里插入图片描述] 测试一下连接百度 [在这里插入图片描述] 可是宝塔面板就是进不去 [在这里插入图片描述] 解决方法 登录服务器控制台,打开安全组 [在这里插入图片描述] 点击修改规则 [在这里插入图片描述] 在协议端口添加 ==,8888
炒香菇的书呆子
2021/05/28
4.8K0
电脑无法打开github
配置了一台新电脑,输入github地址 一直在加载无法打开,确认了不是自己的网络差 解决办法:
河湾欢儿
2020/03/20
4.3K0
无法从/var/lib/rpm打开软件包数据库
centos使用rpm命令安装epel*遇到问题 安装epel*报错 错误:rpmdb: BDB0113 Thread/process 27383/140189131929664 failed: BDB1507 Thread died in Berkeley DB library 错误:db5 错误(-30973) 来自 dbenv->failchk:BDB0087 DB_RUNRECOVERY: Fatal error, run database recovery 错误:无法使用 db5 - (-30
薛定喵君
2019/11/06
3.7K0
网站数据库无法打开 phpMyAdmin启用失败 解决
最近突然网站后台的数据库无法打开,尝试 各种方法,更换PHP版本,卸载、重装phpAdmin都无济于事,最后发现是安全组问题。
梦溪
2021/08/09
2.2K0
Linux服务器数据恢复-服务器修复无法启动错误过程
介绍数据恢复案例前照例先介绍故障服务器的物理状况。本次数据恢复的服务器是linux操作系统,某品牌730系列服务器,MD3200系列存储。导致数据丢失的原因是机房意外断电导致系统无法正常启动,客户管理员对无法访问的服务器进行了修复操作后进入系统查看数据,服务器部分文件已经丢失。于是客户管理员联系了数据恢复中心进行服务器数据恢复。
北亚数据恢复中心
2020/01/13
3.8K0
Linux服务器数据恢复-服务器修复无法启动错误过程
Safari 浏览器无法打开页面 错误是:“cannot parse response" (NSURLErrorDomain: -1017)
nginx 做反向代理,后端web apache服务应用(古老的网站了,也不想动了),有一个web不加www访问的web站点,chrom浏览器正常访问,但是safari浏览器不能正常打开并出现一下错误:
对你无可奈何
2023/06/28
5590
错误: 找不到或无法加载主类(java)
很多刚学java的同学基本上都遇到过这个问题,刚才我刚了一下idea中入口雷类的包的地址,就出现这个了。原因很简单,在此特做记录,希望能帮助到点开这个文章,遇到错误的你。
手撕代码八百里
2020/07/28
5.2K0
IReport无法打开的原因
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说IReport无法打开的原因,希望能够帮助大家进步!!!
Java架构师必看
2021/11/30
2.3K0
IReport无法打开的原因
点击加载更多

相似问题

SQLite java错误“无法打开数据库文件”

10

数据库无法打开,错误: java.lang.NullPointerExecption

13

CMake错误-无法打开输入文件?

10

Lipo错误:无法打开输入文件

40

“无法打开输入文件”crons错误

31
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档