2

我正在尝试在我的级联中使用自定义ListItemComponent但是它忽略了它。它没有绘制我的Label,将其着色为青色并将 ListItemData.text 放入,而是用 ListItemData.description 填充我的列表(我的 json 具有文本、描述、状态和图像)。你可以在这里看到截图。如果我使用StandardListItem所有信息都会正确显示。

QML:

Page {
    Container {
        ListView {
            id: myListView
            dataModel: MyListModel {
                id: myListModel
            }
            listItemComponents: [
                ListItemComponent {
                    type: "listItem"

                    Container {
                        id:item
                        layout: StackLayout {
                            orientation: LayoutOrientation.LeftToRight
                        }
                        Label {
                            id: text
                            text: ListItemData.text
                            textStyle {
                                color: Color.Cyan
                            }
                        }
                    }
                }
            ]
        }
    }
    onCreationCompleted: {
        myListModel.load("app/native/assets/mydata.json")
    }
}

C++:

void MyListModel::load(const QString& file_name)
{
    bb::data::JsonDataAccess jda;
    QVariantList lst = jda.load(file_name).value<QVariantList>();
    if (jda.hasError()) {
        bb::data::DataAccessError error = jda.error();
        qDebug() << file_name << "JSON loading error: " << error.errorType() << ": " << error.errorMessage();
    }
    else {
        qDebug() << file_name << "JSON data loaded OK!";
        append(lst);
    }
}

QVariant MyListModel::value(int ix, const QString &fld_name)
{
    QVariant ret;
    if(ix >= 0 && ix < size()) {
        QVariantMap curr_val = QVariantListDataModel::value(ix).toMap();
        ret = curr_val.value(fld_name);
    }
    return ret;
}

void MyListModel::setValue(int ix, const QString& fld_name, const QVariant& val)
{      
    if(ix >= 0 && ix < size()) { 
        QVariantMap curr_val = QVariantListDataModel::value(ix).value<QVariantMap>();
        curr_val[fld_name] = val;
        replace(ix, curr_val);
    }
}
4

2 回答 2

4

这取决于您的 DataModel 实现/继承的类型。当 ListView 需要知道要显示的项目的类型时,在大多数情况下(请参阅ListItemTypeMapperitemType()以了解例外情况)它从DataModel调用。默认情况下,大多数数据模型将返回一个空字符串,但GroupDataModel将返回“标题”或“项目”,具体取决于项目是否为标题。

您已指定您ListItemComponent仅对“listItem”类型的项目有效,这很可能与您MyListModel::itemType()返回的内容不匹配。如果MyListModel是 a GroupDataModel,则将您的更改ListItemComponent为 for type: "item",否则使用type: ""或完全删除该type属性,以便ListItemComponent默认情况下将您的用于所有项目。

于 2013-03-08T22:53:21.440 回答
0

在 ListItemComponent{ } 中,您有一个“type:”字段,您应该将值设置为“item”,即。类型:“项目”。然后列表视图将使用自定义组件

于 2014-12-18T09:31:55.933 回答