QT开发中文网

qml中Item delegate每一项怎么添加勾选

在QML中,如果你想为每个项添加勾选功能,可以使用Qt Quick Controls的Checkbox组件作为Item Delegate。以下是一个简单示例:

import QtQuick 2.15
import QtQuick.Controls 2.15

ListView {
    width: 200
    height: 300
    
    model: ListModel {
        ListElement { name: "Item 1"; checked: false }
        ListElement { name: "Item 2"; checked: false }
        ListElement { name: "Item 3"; checked: false }
    }
    
    delegate: Item {
        width: parent.width
        height: 40
        
        Row {
            spacing: 10
            
            Checkbox {
                id: checkbox
                checked: model.checked
                
                onCheckedChanged: {
                    // 更新模型中的checked属性
                    model.checked = checked;
                }
            }
            
            Text {
                text: model.name
                verticalAlignment: Text.AlignVCenter
            }
        }
        
        MouseArea {
            anchors.fill: parent
            onClicked: {
                // 点击整个项时,切换checkbox状态
                checkbox.checked = !checkbox.checked;
            }
        }
    } 
}

这样每个项就会显示一个带有文本和勾选框的行,并且点击行或勾选框都可以切换勾选状态。你可以根据自己的需求进行进一步定制和扩展。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://qt.0voice.com/?id=4715

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?