# Navigation Generally, the [Navigation](../reference/arkui-ts/ts-basic-components-navigation.md) component functions as the root container of a page and supports three display modes: single page, column, and adaptive. In addition, Navigation provides properties to set the title bar, toolbar, and navigation bar of a page. The pages of the Navigation component include the home page and content page. The home page consists of the title bar, content area, and toolbar. You can use the [NavRouter](../reference/arkui-ts/ts-basic-components-navrouter.md) child component in the content area to implement the navigation bar function. The content page displays the content of the [NavDestination](../reference/arkui-ts/ts-basic-components-navdestination.md) child component. NavRouter is a special child component used together with Navigation. By default, NavRouter provides click response processing. Developers do not need to customize click event logic. NavRouter has only two root nodes. The second root node is NavDestination. NavDestination is a special child component used together with NavRouter to display the content page of the Navigation component. When a developer clicks the NavRouter component, the corresponding NavDestination content area is displayed. ## Setting the Page Display Mode The Navigation component uses the mode attribute to set the page display mode. - Adaptive Mode By default, the Navigation component is in adaptive mode. In this case, the mode attribute is NavigationMode.Auto. In adaptive mode, when the device width is greater than 520 vp, the Navigation component uses the column mode. Otherwise, the Navigation component uses the single-page mode. ``` Navigation() { ... } .mode(NavigationMode.Auto) ``` - Single-page mode **Figure 1** Layout of a single page ![en-us_image_0000001511740532](figures/en-us_image_0000001511740532.png) Set mode to NavigationMode.Stack so that the Navigation component can be displayed on a single page. ```ts Navigation() { ... } .mode(NavigationMode.Stack) ``` ![Single Page 1] (figures /Single Page 1.jpg) - Column Mode **Figure 2** Column layout ![en-us_image_0000001562820845](figures/en-us_image_0000001562820845.png) Set mode to NavigationMode.Split. The Navigation component is displayed in columns. ```ts @Entry @Component struct NavigationExample { private arr: number[] = [1, 2, 3]; build() { Column() { Navigation() { TextInput({ placeholder: 'search...' }) .width("90%") .height(40) .backgroundColor('#FFFFFF') List({ space: 12 }) { ForEach(this.arr, (item) => { ListItem() { NavRouter() { Text("NavRouter" + item) .width("100%") .height(72) .backgroundColor('#FFFFFF') .borderRadius(24) .fontSize(16) .fontWeight(500) .textAlign(TextAlign.Center) NavDestination() { Text("NavDestinationContent" + item) } .title("NavDestinationTitle" + item) } } }, item => item) } .width("90%") .margin({ top: 12 }) } .title ("Main Title") .mode(NavigationMode.Split) .menus([ {value: "", icon: "./image/ic_public_search.svg", action: ()=> {}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=> {}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=> {}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=> {}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=> {}} ]) .toolBar({items: [ {value: "func", icon: "./image/ic_public_highlights.svg", action: ()=> {}}, {value: "func", icon: "./image/ic_public_highlights.svg", action: ()=> {}}, {value: "func", icon: "./image/ic_public_highlights.svg", action: ()=> {}} ]}) } .height('100%') .width('100%') .backgroundColor('#F1F3F5') } } ``` ![Column](figures/Column.jpg) ## Setting the Title Bar Mode The title bar is on the top of the page and is used to display the page name and operation entry. The Navigation component uses the titleMode property to set the title bar mode. - Mini mode Common title bar, which is used when the title of a level-1 page does not need to be highlighted. **Figure 3** Title bar in Mini mode ![mini](figures/mini.jpg) ```ts Navigation() { ... } .titleMode(NavigationTitleMode.Mini) ``` - Full mode Emphasis title bar, which is used when the title of a level-1 page needs to be highlighted. **Figure 4** Title bar in Full mode ![free1](figures/free1.jpg) ```ts Navigation() { ... } .titleMode(NavigationTitleMode.Full) ``` ## Setting Menu Bar The menu bar is in the upper right corner of the Navigation component. Developers can set the menu bar through the menus property. The menus supports two parameter types: Array<[NavigationMenuItem](../reference/arkui-ts/ts-basic-components-navigation.md#navigationmenuitem %E7%B1%BB %E5%9E %8B %E8%AF %B4%E6%98%8E)> and CustomBuilder. When the Array type is used, a maximum of three icons can be displayed in portrait mode and a maximum of five icons can be displayed in landscape mode. Extra icons will be placed in the automatically generated More icons. **Figure 5** Menu bar with three icons ![menu-bar-2](figures/menu-bar-2.jpg) ```ts Navigation() { ... } .menus([{value: "", icon: "./image/ic_public_search.svg", action: ()=>{}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=>{}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=>{}}]) ``` **Figure 6** Menu bar with four icons ![menu-bar](figures/menu-bar.jpg) ```ts Navigation() { ... } .menus([{value: "", icon: "./image/ic_public_search.svg", action: ()=>{}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=>{}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=>{}}, {value: "", icon: "./image/ic_public_add.svg", action: ()=>{}}]) ``` ## Setting the Toolbar The toolbar is located at the bottom of the Navigation component. Developers can set the toolbar by setting the toolbar properties. **Figure 7** Toolbar ![free3](figures/free3.jpg) ```ts Navigation() { ... } .toolBar({items:[ {value: "func", icon: "./image/ic_public_highlights.svg", action: ()=>{}}, {value: "func", icon: "./image/ic_public_highlights.svg", action: ()=>{}}, {value: "func", icon: "./image/ic_public_highlights.svg", action: ()=>{}}]}) ```