5.自定义侧边导航菜单组件(基于menubar,menu,menuitem)

目录

效果预览

qml中实现可折叠的侧边导航栏方法 使用menubar 与menubaritem ,menu,menuitem是做不到的

为此将以上组件重写,实现侧边可折叠

使用代码

复制代码
import QtQuick 2.12
import BinUI 1.0
import QtQuick.Controls 2.12
import "../"

Item {


    // 动态创建

    Component.onCompleted: {


        // 动态创建菜单栏
        for(var i = 0;i<lm.length;i++){
            var menuInfo = com_menu.createObject(menuBar,{title:lm[i].label,visible:lm[i].opened});
            if(lm[i].children){
                for(var j=0;j<lm[i].children.length ;j++){
                    var menuInfo1 = com_menu.createObject(menuBar,{title:lm[i].children[j]});
                    menuInfo.addMenu(menuInfo1)
                }
            }
            menuBar.addMenu(menuInfo)
        }

    }

    property var  lm: [
        {label:qsTr("导航1"),children:["选项1"],opened:true}, //默认展开
        {label:qsTr("导航2"),children:[]},
        {label:qsTr("导航3"),children:["选项1"]},
        {label:qsTr("导航4"),children:[]},
    ]



    Column{
        x: 10
        y: 10
        spacing: 10

        Row{
            Label{
                text: qsTr("当前被选中的菜单项:")
            }
            Label{
                id: selectedMenu_Label
            }
        }

        BinMenuBar{
            id: menuBar

            onSelectedChanged: {
                selectedMenu_Label.text = instance.text
            }
        }


    }

    Component{
        id: com_menu
        Menu{
        }
    }


}
相关推荐
水煎包V:YEDIYYDS8886 天前
QT QML 实现的旋钮按钮,类似收音机音量旋钮,可指示方向和角度
qt·qml·旋钮组件
水煎包V:YEDIYYDS88810 天前
QT 在 QML中 嵌入显示qwidget界面显示的两种方式,已在项目中验证
qt·qml·qt开发·qwidget
水煎包V:YEDIYYDS88810 天前
QT QML 实现的摇杆按钮,类似王者荣耀 左边方向导航键
qt·qml·摇杆按钮·导航键
千疑千寻~16 天前
【QML】C++访问QML控件
c++·qml
Wallace Zhang17 天前
PySide6 + QML - Charts07 - 使用checkbox选择需要显示的曲线
vscode·pyside6·qml
千疑千寻~17 天前
【QML】自定义控件
qml
Wallace Zhang1 个月前
PySide6 + QML - 调试日志01 -告别打印log中文乱码,快速且简单地解决
qt·pyside6·qml
江公望1 个月前
Qt QHostInfo::lookupHost()函数,10分钟讲清楚
开发语言·qt·qml
江公望1 个月前
Qt告警clazy-detaching-temporary浅谈
qt·qml
Hi202402171 个月前
为QML程序添加启动Logo:提升用户体验
windows·qt·ui·人机交互·qml·启动logo