首页 > 解决方案 > 使用动态对象时如何让 Radio 处理颤振?

问题描述

我是 Flutter 的新手,我对 Radio 有疑问。使用“常规”方法时,我让它完美地工作:

int _groupValue=-1;
...
...
child: Align(
                alignment: Alignment.center,
                child: Column(
                  children: <Widget>[
                    RadioListTile(activeColor: Colors.black,
                      groupValue: _groupValue,
                      value: 1,
                      onChanged: (value) { setState(() {
                        _groupValue=value;
                      });  },
                      title: Text("a"),
                    ),
                    RadioListTile(activeColor: Colors.black,
                      groupValue: _groupValue,
                      value: 2,
                      onChanged: (value) { setState(() {
                        _groupValue=value;
                      });  },

                      title: Text("b"),
                    ),
                  ],
                ),
              ),

由于我使用 API 中的数据来创建单选按钮,因此我已将此代码更改为:

child: Align(
                    alignment: Alignment.center,
                    child:            children: radioListView
                    ),
                  ),

并单击一个按钮,我调用异步方法从 API 下载数据,如下所示:

void getApiData() async {
    ...
    ...
    ...
    setState() { 
        var radioListView = List<RadioListTile>();
        for (Map<String, dynamic> c in apidata)) {
          radioListView.add(new RadioListTile(
            groupValue: _groupValue,
              value: c['option_value'],
            title: c['title'],
            onChanged: (value) { setState(() {
                        _groupValue=value;
                      });
            ),

          ));
      }
    }
} 

使用第一个代码它可以工作,但是使用第二个代码我只是看到了这些项目,但是当我单击单选按钮时什么也没有发生(尽管 onchanged 确实触发了,因为我试图打印值并且很好)我做错了什么?

标签: flutterflutter-radiobutton

解决方案


我在这里找到了解决方案: https ://www.didierboelens.com/2018/05/hint-5-how-to-refresh-the-content-of-a-dialog-via-setstate/

问题是我必须分离小部件并为收音机创建另一个有状态的小部件


推荐阅读