qml ListModel与Repeater编写重复控件界面

ListModel与Repeater编写重复控件界面实例,当热要实现重复控件的方式有很多种,例如使用Listview、Repeater 等,但为什么要写这种方式,主要是平时使用的比较少加深一下印象,废话不多说。

Rectangle{
        id:equip
        anchors.fill: parent
        color:"#A0000000"
        radius:10
        border{color:"white";width:2}
        Column{
            anchors.centerIn: parent
            spacing: 20
            ListModel{
                id:paraModel
                property var valueFunc:{
                    "text1":{get:test.gettext1,set:test.settext1},
                    "text2":{get:test.gettext2,set:test.settext1},
                    "text3":{get:test.gettext3,set:test.settext1},
                    "text4":{get:test.gettext4,set:test.settext1},
                    "text5":{get:test.gettext5,set:test.settext1},
                    "text6":{get:test.gettext6,set:test.settext1},
                    "text7":{get:test.gettext7,set:test.settext1},
                    "text8":{get:test.gettext8,set:test.settext1},
                    "text9":{get:test.gettext9,set:test.settext1}
                }
                ListElement{
                    name:QT_TR_NOOP("text1");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text2");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text3");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text4");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text5");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text6");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text7");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text8");unit:qsTr("s")
                }
                ListElement{
                    name:QT_TR_NOOP("text9");unit:qsTr("s")
                }
            }
            Repeater{
                id:repeater
                model:paraMode
                Row {
            id: row
            spacing: 5
            MyComp.LightText{
                id: startText
                text:qsTr(name);
            }
            MyComp.LightTextInput{
                id: infoInput
                focus: true
                onReturnValue: {
                            paraModel.valueFunc[name].set(txtvalue)
                            changed = true
                            }
            }
            MyComp.LightText{
                id: units
                text:unit
            }
            }
            }
            Component.onCompleted: {
                var i
                for(i = 0; i < repeater.count;i++){
                    var item = repeater.itemAt(i)
                    item.KeyNavigation.down = repeater.itemAt((i+1)%repeater.count)
                }
            }
        }
    }

没什么技术难度所以就不解释了。

QML 中,你可以使用 ListModelListView 来根据数组生成多个按钮。 首先,你需要创建一个 ListModel,将按钮的标签作为模型的属性,例如: ```qml ListModel { id: buttonModel ListElement { text: "Button 1" } ListElement { text: "Button 2" } ListElement { text: "Button 3" } } ``` 然后,你可以使用 ListView 来显示这个 ListModel 中的所有元素,并将每个元素渲染为一个按钮,例如: ```qml ListView { model: buttonModel delegate: Button { text: model.text onClicked: console.log("Button clicked:", model.text) } } ``` 这个代码段使用 ListView 来显示 buttonModel 中的所有元素。每个元素都被渲染为一个 Button 控件,其文本内容设置为模型的 text 属性。当按钮被点击时,它会输出一个消息到控制台,显示按钮的文本内容。 这样,你就可以根据数组生成多个按钮了。如果你想从 JavaScript 代码中更新 ListModel 中的元素,可以使用 JavaScript 数组和 Qt.binding 函数来实现。例如: ```qml property var buttonLabels: ["Button 4", "Button 5", "Button 6"] ListModel { id: buttonModel Repeater { model: buttonLabels.length delegate: ListElement { text: buttonLabels[index] } } } ListView { model: buttonModel delegate: Button { text: model.text onClicked: console.log("Button clicked:", model.text) } } ``` 这个代码段将 JavaScript 数组 buttonLabels 定义为一个属性,并使用 Repeater 将其转换为 ListModel 中的元素。当 buttonLabels 数组发生变化时,ListModel 也会自动更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值