访问QML中委托内的modelData

时间:2016-09-26 14:59:44

标签: qt view model qml repeater

有没有办法访问' modelData'来自View delegate(特别是Repeater)。

我尝试使用单独的属性并尝试通过' model.modelData'来访问它。但这都不起作用。

请参阅下面的代码快照。

提前致谢。

Component
{
    id: comp_1
    Rectangle
    {
        color: "green"
        width: 200
        height: 200
    }
}

Component
{
    id: comp_2
    Rectangle
    {
        color: "red"
        width: 200
        height: 200

        Text
        {
            anchors.fill: parent
            text: modelData
            horizontalAlignment: Text.AlignHCenter
            verticalAlignment: Text.AlignVCenter
        }
    }
}



function getDelegate(itemName)
{
    if(itemName === "comp1")
        return comp_1;
    else
        return comp_2;
}

Row
{
    Repeater
    {
        id: repeat

        model: ["comp1", "comp2"]

        Loader
        {
            sourceComponent: getDelegate(modelData)
        }
    }
}

1 个答案:

答案 0 :(得分:4)

您可以在委托元素

上添加属性
Component {
    id: comp_1
    Rectangle {
        property string valueFromModel
    }
}

并将modelData绑定到它

Loader {
    id: loader
    Binding {
        target: loader.item
        property: "valueFromModel"
        value: model.modelData
    }
}