Sailfish应用开发入门(五)PageStack、Button使用

        PageStack提供了基于栈的Sailfish UI导航模型。
        PageStack由多个page页面组成,一个页面可以push到栈里面替代栈顶的page,或者从栈里移除某个page。
        Sailfish 应用被创建的时候PageStack就已经包含了一个page,这个page是由ApplicationWindow initialPage属性指定的。
        PageStack属性:
            busy:bool 当PageStack正在进行push或pop的时候为true
            currentPage:item PageStack栈顶page
            depth: int PageStack当前有多少个page

        PageStack方法:
           PageStack:clear() 从栈里移除所有page
           PageStack:find(function) 从栈顶到栈底搜索page,知道遇到function返回true的时候。function必须是一个js方法对象,接收page参数并且返回true或者false。
           PageStack:openDialog(dialog, properties, immediate)  压入一个Dialog到栈里面
           PageStack::pop(page, immediate) 从栈里移除page,如果没有传入page参数,则移除当前page。
           PageStack::push(page, properties, immediate)  向栈里压入一个page。page可以是Item、Component、qml的url或page数组。
           PageStack::replace(page, properties, immediate)
           PageStack::replaceWithDialog (dialog, properties, immediate)

//main.qml
import QtQuick 1.1
import Sailfish.Silica 1.0
import "pages"

ApplicationWindow
{
    initialPage: Page {
        id: page
        Item {
            id: item
            anchors.centerIn: parent
            Button {
                id: btn1
                text: "Button1"
                onClicked: pageStack.push(Qt.resolvedUrl("pages/FirstPage.qml"))
            }

            Button {
                id: btn2
                anchors.baseline: btn1.bottom
                text: "Button2"
                onClicked: pageStack.push(Qt.resolvedUrl("pages/SecondPage.qml"))
            }
        }
    }
    cover: Qt.resolvedUrl("cover/CoverPage.qml")
}

  

//FirstPage.qml
import QtQuick 1.1
import Sailfish.Silica 1.0

Page {
    id: page
    Button {
        anchors.horizontalCenter: page.horizontalCenter
        anchors.baseline: page.baseline
        text: "Back"
       onClicked: pageStack.pop()
    }

    Label {
        anchors.centerIn: parent
        text: "This is FirstPage"
    }
}


//SecondPage.qml
import QtQuick 1.1
import Sailfish.Silica 1.0

Page {
    id: page
    Button {
        anchors.horizontalCenter: page.horizontalCenter
        anchors.baseline: page.baseline
        text: "Back"
        onClicked: pageStack.pop()
    }

    Label {
        anchors.centerIn: parent
        text: "This is SecondPage"
    }
}



 


     

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值