实现Tabview的另一种方式

 
 
  function showZLForm()
    {
        if(sForm === null)
        {
            var ckCom = Qt.createComponent("qrc:/1.qml");
            if(ckCom.status === Component.Ready)
            {
 
 
           sForm = ckCom.createObject(rec);
             sForm .anchors.fill = rec;
               sForm.visible = Qt.binding(function(){return tab.currentIndex === 0})
            }
            else
            {
                console.debug("巡检查看新建错误:", ckCom.errorString());
            }
            ckCom.destroy();
        }
 
         if(sForm!== null)
         {
             sForm.initData(0);
         }
    }
 
 
// 底部的tab菜单导航
    Row{
        id: tab;
 
        property int currentIndex: -1;
 
        width: visible ? parent.width : 0;
        anchors.bottom: parent.bottom;
        //anchors.bottomMargin:  10*pixelRate;
        //spacing: 10*pixelRate;
 
        Rectangle{
            id: sbzlBtn;
 
            width: parent.width / 2;
            height: pqphText.contentHeight * 2 + 6 * pixelRate;
            color: tab.currentIndex === 0 ? "#41BBAF" : "#E4E4E4";
            NSText{
                id: pqphText;
                text: qsTr("资料");
                verticalAlignment: Text.AlignVCenter;
                horizontalAlignment: Text.horizontalCenter;
                font.pixelSize: 12 * pixelRate;
                anchors.centerIn: parent;
                color: tab.currentIndex === 0 ? "black" : "black";
            }
 
            MouseArea{
                id: pqphMouse;
                anchors.fill: parent;
                onClicked: {
                    tab.currentIndex = 0;
                    showzlForm();
                }
            }
        }
 
 
        Rectangle{
            id: jkBtn;
            width: parent.width/2;
            height: jkText.contentHeight * 2 + 6 * pixelRate;
            color: tab.currentIndex === 1 ? "#41BBAF" : "#E4E4E4";
            NSText{
                id: jkText;
                text: qsTr("111");
                verticalAlignment: Text.AlignVCenter;
                horizontalAlignment: Text.horizontalCenter;
                font.pixelSize: 12 * pixelRate;
                anchors.centerIn: parent;
                color: tab.currentIndex === 1 ? "black" : "#black";
            }
 
            MouseArea{
                id: jkMouse;
                anchors.fill: parent;
                onClicked: {
                    tab.currentIndex = 1;
 
                    showForm();
                }
            }
        }
 
    }

                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值