Flutter ReorderableListView 与自定义对象

Posted

技术标签:

【中文标题】Flutter ReorderableListView 与自定义对象【英文标题】:Flutter ReorderableListView with custom object 【发布时间】:2020-10-12 03:21:09 【问题描述】:

我目前在使用 ReorderableListView 时遇到了一些困难。

我有一个 ToDoPrefabs 列表,我想输出它,因为我的列表不包含字符串而是其他内容,我在索引中遇到错误,对于键和文本。

这是错误:

"type 'To Prefab' 不是 type 'int' 的子类型"

我怀疑这是关键。这也是合乎逻辑的,因为 todoprefab 不是 int。有谁知道如何在我的 ReorderableListView 中获得另一个 int 类型的索引

这是我的 ReorderableListView

return ReorderableListView(
      onReorder: _onReorder,
      scrollDirection: Axis.vertical,
      padding: const EdgeInsets.symmetric(vertical: 8.0),
      children: [
        for(final item in toDoManagerClass.todoBank)
        todocardprefab(item)
      ]
    );

tod​​ocardprefab(不是列表)

todocardprefab(var key)
  return Dismissible(
    key: ValueKey(key),
    background: Container(color: Colors.red, alignment: Alignment.centerLeft, child: Icon(Icons.delete),),
    secondaryBackground: Container(color: Colors.green, alignment: Alignment.centerRight, child: Icon(Icons.archive),),
    child: Card(
      child: ListTile(
        //leading: Icon(Icons.check_box_outline_blank),
        title: Text(toDoManagerClass.todoBank[key].toDoText),
        onTap: (),
      ),
    ),
  );

这是一个简单的列表。

class ToDoManagerClass
  List<ToDoPrefab> todoBank = [
    ToDoPrefab(text: 'Homework', f: false),
    ToDoPrefab(text: 'Homework1', f: false),
    ToDoPrefab(text: 'Homework12', f: false),
    ToDoPrefab(text: 'Homework123', f: false),
    ToDoPrefab(text: 'Homework1234', f: false),
    ToDoPrefab(text: 'Homework12345', f: false),
  ];

【问题讨论】:

【参考方案1】:

这个方法应该有效:

您的可重新排序的列表视图

return ReorderableListView(
      onReorder: _onReorder,
      scrollDirection: Axis.vertical,
      padding: const EdgeInsets.symmetric(vertical: 8.0),
      children: [
        for(final item in toDoManagerClass.todoBank)
        todocardprefab(item, index())
      ]
    );

这里是函数。每次调用都会返回一个更高的数字。

int index()
    if(i < toDoManagerClass.todoBank.length)
      print(i);
      i++;
    
    return i-1;
  

现在您只需使用索引而不是 todocard 中的项目

【讨论】:

以上是关于Flutter ReorderableListView 与自定义对象的主要内容,如果未能解决你的问题,请参考以下文章

Flutter 致命错误:找不到“Flutter/Flutter.h”文件

[Flutter] flutter项目一直卡在 Running Gradle task 'assembleDebug'...

flutter 日志输出,Flutter打印日志,flutter log,flutter 真机日志

Flutter开发 Flutter 包和插件 ( Flutter 包和插件简介 | 创建 Flutter 插件 | 创建 Dart 包 )

flutter与原生混编(iOS)

Flutter-布局