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)
                }
            }
        }
    }

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值