首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >更改子属性不会触发颤振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

复制
相关文章
解决Chrome 浏览器翻译提示错误:无法翻译此页面问题
由于谷歌停止了中国大陆的翻译服务,导致Chrome浏览器无法使用自带全文翻译功能,点击翻译会出现:
用户4623659
2023/03/21
2K0
解决Chrome 浏览器翻译提示错误:无法翻译此页面问题
无法安装此app,因为无法验证其完整性 ,解决方案
最近有很多兄弟萌跟我反应“无法安装此app,因为无法验证其完整性 ”,看来这个问题无法避免了,今天统一回复下,出现提示主要有以下几种可能
爱学iOS的小麦子
2023/06/30
7.8K0
Firebase 如何创建登录 Token
Firebase 的 token 可以使用 firebase 命令行工具来进行创建。
HoneyMoose
2021/04/02
2.5K0
Firebase 如何创建登录 Token
【错误记录】Android 应用连接 BLE 设备无法读取数据 ( 可以写出数据 | 无法读取数据 )
发送数据成功 : Android 应用 向 BLE 硬件设备发送数据 , 成功 ;
韩曙亮
2023/03/28
1.6K0
visual studio 2019出现无法登录 无法刷新此用户凭证解决方式
我这里是已经解决好后的了,首先出现那个过了试用期30天然后阻止你再用的时候,看了好多解决方式,有什么换网络我试了没有什么用,最起码在我电脑上没有用,后面又说在下载那边启用然后快速的找到“帮助”“发送反馈“”报告问题”,就会有登录自己的账号,没有的话就得去注册一下了,这个方式顺过来解决了问题。
meihuasheng
2021/03/18
2.5K0
错误代码502,网页无法打开?教你如何解决!
在使用互联网的过程中,我们时常会遇到各种错误代码,其中502错误代码是最为常见的一种。502 Bad Gateway错误表示,网关或代理服务无法将请求发送到上游服务器。那么,错误代码502是什么意思?
德迅云安全--陈琦琦
2023/10/08
10.1K0
Pages 无法使用此AppleID更新
无法更新是因为这个应用并没有绑定到已经登录的AppleID中,点击已购,会提示有应用需要接受,点击全部接受。输入几次密码之后再次更新就ok了、
obaby
2023/02/23
1K0
Google 的 Firebase 如何删除项目
https://www.ossez.com/t/google-firebase/13792
HoneyMoose
2021/11/02
3.2K0
Google 的 Firebase 如何删除项目
opencv无法读取图片_opencv无法读取图片
使用一下代码读取一张图片失败(不管是绝对路径还是相对路径,都失败),工程运行都没问题,就是图片读取失败。
全栈程序员站长
2022/11/04
2.4K0
解决 无法读取到 /data/data/yourPackageName/files/coverage.ec 文件
参考 https://testerhome.com/topics/8554 这篇文章
全栈程序员站长
2022/09/13
1K0
pandas文件读取错误及解决办法
错误一:‘gbk’ codec can’t decode byte 0x98 in position 2: illegal multibyte sequence
诡途
2022/05/09
1.3K0
firebase怎么用_firebase是什么
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168361.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/20
4.2K0
firebase怎么用_firebase是什么
Windows IIS注册asp 此操作系统版本不支持此选项 错误解决方法
更新Win10,原来的IIS站点访问不了,原因是因为IIS 没有.net 4.5,使用网上的aspnet_regiis.exe -i命令,一点都不靠谱,直接提示:
庞小明
2018/12/24
4.4K0
Cornerstone3无法读取 log 的解决办法
但是这一篇文章并没有解决好我的问题,问题依旧,最后发现自从 Cornerstone3之后就换了标识符,就起不到效果。
君赏
2018/08/31
2K0
Cornerstone3无法读取 log 的解决办法
Mac无法读取硬盘
问题描述: 由于没有弹出移动硬盘,就拔出来了。导致再插入硬盘,电脑也无法识别了。 步骤: 1.查看一下硬盘信息 画圈的就是我的硬盘。 2.将这个硬盘挂载 sudo diskutil mount /dev/disk2s1 然后需要输入的就是你的密码(开机密码) 可以看到,已经挂载成功了。
用户4793865
2023/01/12
1.1K0
dz2.5 后台空白 登陆等到处提示内部错误,无法显示此内容
源出于对一个垃圾站的搬家,直接搬了文件和数据库,结果出现标题的错误,经过几天的百度等。 找到了答案: 就是这个 congig_global.php 看看最下面有没有多余的行数。删除多余的行数。 —————————————————————————————————————————————————————————————————————————————————— 详细解释: 1。提示内部错误的时候,大家就可以安心了,因为一般都是xml格式的问题,稍微调试一下就好了 对方修改了config文件,导致出现问题,并声
用户1272546
2018/06/05
8720
dz2.5 后台空白 登陆等到处提示内部错误,无法显示此内容
源出于对一个垃圾站的搬家,直接搬了文件和数据库,结果出现标题的错误,经过几天的百度等。
用户1191760
2019/02/27
1K0
SUMMARIZE函数解决之前的总计错误
这些都是之前的文件,这里拿出来是为了方便小伙伴们观看对比使用的。先来说一下什么意思:
PowerBI丨白茶
2021/09/02
7870
SUMMARIZE函数解决之前的总计错误
点击加载更多

相似问题

用于Firebase类型错误的云函数-无法读取属性

20

无法解决此错误。Kotlin -Firebase

25

Firebase实时云函数-无法读取空快照的属性

152

firebase云函数无法读取未定义的属性“ref”

20

Firebase云函数无法读取未定义的属性“”displayName“”

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

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

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文