ts-basic-components-navigation.md 6.4 KB
Newer Older
Z
zengyawen 已提交
1 2 3
# Navigation


4
> **NOTE**<br>
Z
zengyawen 已提交
5 6 7 8 9 10 11 12 13 14 15
> This component is supported since API version 8. Updates will be marked with a superscript to indicate their earliest API version.


The **&lt;Navigation&gt;** component typically functions as the root container of a page and displays the page title, toolbar, and menu based on the attribute settings.


## Required Permissions

None


E
esterzhou 已提交
16
## Child Components
Z
zengyawen 已提交
17

E
esterzhou 已提交
18
Supported
Z
zengyawen 已提交
19 20 21 22 23 24 25 26 27 28 29


## APIs

Navigation()

Creates a component that can automatically display the navigation bar, title, and toolbar based on the attribute settings.


## Attributes

E
esterzhou 已提交
30
| Name | Type | Default Value | Description |
Z
zengyawen 已提交
31
| -------- | -------- | -------- | -------- |
E
ester.zhou 已提交
32
| title | string \| [CustomBuilder](../../ui/ts-types.md)<sup>8+</sup> | - | Page title. |
E
esterzhou 已提交
33
| subtitle | string | - | Subtitle of the page. |
E
ester.zhou 已提交
34
| menus | Array&lt;NavigationMenuItem&gt; \| [CustomBuilder](../../ui/ts-types.md)<sup>8+</sup> | - | Menu in the upper right corner of the page. |
E
esterzhou 已提交
35
| titleMode | NavigationTitleMode | NavigationTitleMode.Free | Display mode of the page title bar. |
E
ester.zhou 已提交
36
| toolBar | {<br/>items:[<br/>Object<br/>] }<br/>\| [CustomBuilder](../../ui/ts-types.md)<sup>8+</sup> | - | Content of the toolbar.<br/>**items**: all items on the toolbar. |
E
esterzhou 已提交
37 38 39
| hideToolBar | boolean | false | Whether to hide the toolbar.<br/>**true**: Hide the toolbar.<br/>**false**: Show the toolbar. |
| hideTitleBar | boolean | false | Whether to hide the title bar. |
| hideBackButton | boolean | false | Whether to hide the back button. |
Z
zengyawen 已提交
40 41

- NavigationMenuItem attributes
42
  | Name | Type | Mandatory | Default Value | Description |
Z
zengyawen 已提交
43
  | -------- | -------- | -------- | -------- | -------- |
E
esterzhou 已提交
44 45 46
  | value | string | Yes | - | Text of an option on the menu bar. |
  | icon | string | No | - | Icon path of an option on the menu bar. |
  | action | () =&gt; void | No | - | Callback invoked when an option is selected. |
Z
zengyawen 已提交
47 48

- Object attributes
49
  | Name | Type | Mandatory | Default Value | Description |
Z
zengyawen 已提交
50
  | -------- | -------- | -------- | -------- | -------- |
E
esterzhou 已提交
51 52 53
  | value | string | Yes | - | Text of an option on the toolbar. |
  | icon | string | No | - | Icon path of an option on the toolbar. |
  | action | () =&gt; void | No | - | Callback invoked when an option is selected. |
Z
zengyawen 已提交
54 55

- NavigationTitleMode enums
56
  | Name | Description |
Z
zengyawen 已提交
57
  | -------- | -------- |
E
esterzhou 已提交
58 59 60
  | Free | When the content is a scrollable component, the title shrinks as the content scrolls up (the subtitle fades out with its size remaining unchanged) and restores as the content scrolls down. |
  | Mini | The mode is fixed at mini mode (icon + main title and subtitle). |
  | Full | The mode is fixed at full mode (main title and subtitle). |
Z
zengyawen 已提交
61

62
  > **NOTE**
Z
zengyawen 已提交
63 64 65 66 67
  > Currently, only the scrollable component **&lt;List&gt;** is supported.


## Events

E
esterzhou 已提交
68
| Name | Description |
Z
zengyawen 已提交
69
| -------- | -------- |
E
ester.zhou 已提交
70
| onTitleModeChange(callback:&nbsp;(titleMode:&nbsp;NavigationTitleMode)&nbsp;=&gt;&nbsp;void) | Triggered when **titleMode** is set to **NavigationTitleMode.Free** and the title bar mode changes as content scrolls. |
Z
zengyawen 已提交
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142


## Example


```
// Example 01
@Entry
@Component
struct NavigationExample {
  private arr: number[] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
  @State hideBar: boolean = true

  @Builder NavigationTitle() {
    Column() {
      Text('title')
        .width(80)
        .height(60)
        .fontColor(Color.Blue)
        .fontSize(30)
    }
    .onClick(() => {
      console.log("title")
    })
  }

  @Builder NavigationMenus() {
    Row() {
      Image('images/add.png')
        .width(25)
        .height(25)
      Image('comment/more.png')
        .width(25)
        .height(25)
        .margin({ left: 30 })
    }.width(100)
  }

  build() {
    Column() {
      Navigation() {
        Search({ value: '', placeholder: "" }).width('85%').margin(26)
        List({ space: 5, initialIndex: 0 }) {
          ForEach(this.arr, (item) => {
            ListItem() {
              Text('' + item)
                .width('90%')
                .height(80)
                .backgroundColor('#3366CC')
                .borderRadius(15)
                .fontSize(16)
                .textAlign(TextAlign.Center)
            }.editable(true)
          }, item => item)
        }
        .listDirection(Axis.Vertical)
        .height(300)
        .margin({ top: 10, left: 18 })
        .width('100%')

        Button(this.hideBar ? "tool bar" : "hide bar")
          .onClick(() => {
            this.hideBar = !this.hideBar
          })
          .margin({ left: 135, top: 60 })
      }
      .title(this.NavigationTitle)
      .subTitle('subtitle')
      .menus(this.NavigationMenus)
      .titleMode(NavigationTitleMode.Free)
      .hideTitleBar(false)
      .hideBackButton(false)
E
ester.zhou 已提交
143
      .onTitleModeChange((titleModel: NavigationTitleMode) => {
Z
zengyawen 已提交
144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
        console.log('titleMode')
      })
      .toolBar({ items: [
        { value: 'app', icon: 'images/grid.svg', action: () => {
          console.log("app")
        } },
        { value: 'add', icon: 'images/add.svg', action: () => {
          console.log("add")
        } },
        { value: 'collect', icon: 'images/collect.svg', action: () => {
          console.log("collect")
        } }] })
      .hideToolBar(this.hideBar)
    }
  }
}
```

![en-us_image_0000001256978359](figures/en-us_image_0000001256978359.gif)


```
// Example 02
@Entry
@Component
struct ToolbarBuilderExample {
  @State currentIndex: number = 0
  @State Build: Array<Object> = [
    {
      icon: $r('app.media.ic_public_add'),
      icon_after: $r('app.media.ic_public_addcolor'),
      text: 'add',
      num: 0
    },
    {
      icon: $r('app.media.ic_public_app'),
      icon_after: $r('app.media.ic_public_appcolor'),
      text: 'app',
      num: 1
    },
    {
      icon: $r('app.media.ic_public_collect'),
      icon_after: $r('app.media.ic_public_collectcolor'),
      text: 'collect',
      num: 2
    }
  ]

  @Builder NavigationToolbar() {
    Row() {
      ForEach(this.Build, item => {
        Column() {
          Image(this.currentIndex == item.num ? item.icon_after : item.icon)
            .width(25)
            .height(25)
          Text(item.text)
            .fontColor(this.currentIndex == item.num ? "#ff7500" : "#000000")
        }
        .onClick(() => {
          this.currentIndex = item.num
        })
        .margin({ left: 70 })
      })
    }
  }

  build() {
    Column() {
      Navigation() {
        Flex() {
        }
      }
      .toolBar(this.NavigationToolbar)
    }
  }
}
```

![en-us_image_0000001212058484](figures/en-us_image_0000001212058484.gif)