Page rows and page stacks
Add flow to your application: Add, remove and replace pages in different ways
Last updated
Add flow to your application: Add, remove and replace pages in different ways
Last updated
We have seen so far that one of the core components of a Kirigami window is a . A single page can envelop the whole screen of the application, or it can be shown together with other pages at the same time, if there is space.
Whenever a page gets added, or pushed, it appears to the right of the existing page(s), forming a row. This row of pages can be managed with the fittingly named .
A minimal page row with a single page could look like this:
The previous example can be reduced significantly with a pageStack
, with the added bonus of navigation actions:
and
There are two improvements that can be done here. The first is that, with , we can both set mainPage
to be the first page that appears in the page row, and have its dimensions be managed by the page row instead of via manual , or . The second is to have a toolbar, which can be set by defining a toolbar style with . There are a few styles we can choose from, but we'll go with for now.
There are only two ways of adding pages to a page row: by setting its (which can optionally take an array of pages) or by using . To delete a page from the page row, you should use , whereas or can be used to navigate between pages.
If a with a toolbar looks familiar to you, that is because you have seen it before. An is nothing more than a very convenient, global page row. Every function available to a PageRow
is also available to the pageStack
.
In general you'll want to use a pageStack
rather than implement your own , especially when your application gets bigger and you need your components living in separate files. If you create your window in your Main.qml
using a , a component residing in another file can still directly invoke the global pageStack
by means of a call to the :