ts-container-badge.md 5.1 KB
Newer Older
Z
zengyawen 已提交
1 2
# Badge

T
explain  
tianyu 已提交
3 4
可以附加在单个组件上用于信息标记的容器组件。

H
geshi  
HelloCrease 已提交
5
>  **说明:**
Z
zengyawen 已提交
6
> 该组件从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
Z
zengyawen 已提交
7

Z
zengyawen 已提交
8

Z
zengyawen 已提交
9
## 子组件
Z
zengyawen 已提交
10

Z
zengyawen 已提交
11
支持单个子组件。
Z
zengyawen 已提交
12 13


Z
zengyawen 已提交
14
## 接口
Z
zengyawen 已提交
15

16
**方法1:** Badge(value: {count: number, position?: BadgePosition, maxCount?: number, style: BadgeStyle})
Z
zengyawen 已提交
17

K
kangchongtao 已提交
18
创建数字标记组件。
S
sienna1128 已提交
19

S
sienna1128 已提交
20
**参数:**
W
wangshuainan 已提交
21 22 23
| 参数名 | 参数类型 | 必填 | 默认值 | 参数描述 |
| -------- | -------- | -------- | -------- | -------- |
| count | number | 是 | - | 设置提醒消息数。 |
24
| position | [BadgePosition](#badgeposition枚举说明) | 否 | BadgePosition.RightTop | 设置提示点显示位置。 |
W
wangshuainan 已提交
25
| maxCount | number | 否 | 99 | 最大消息数,超过最大消息时仅显示maxCount+。 |
26
| style | [BadgeStyle](#badgestyle对象说明) | 是 | - | Badge组件可设置样式,支持设置文本颜色、尺寸、圆点颜色和尺寸。 |
Z
zengyawen 已提交
27

28
**方法2:** Badge(value: {value: string, position?: BadgePosition, style: BadgeStyle})
Z
zengyawen 已提交
29

S
sienna1128 已提交
30
根据字符串创建标记组件。
K
kangchongtao 已提交
31 32

**参数:**
Z
zengyawen 已提交
33

34 35 36 37 38 39 40
| 参数名 | 参数类型 | 必填 | 默认值 | 参数描述 |
| -------- | -------- | -------- | -------- | -------- |
| value | string | 是 | - | 提示内容的文本字符串。 |
| position | [BadgePosition](#badgeposition枚举说明) | 否 | BadgePosition.RightTop | 设置提示点显示位置。 |
| style | [BadgeStyle](#badgestyle对象说明) | 是 | - | Badge组件可设置样式,支持设置文本颜色、尺寸、圆点颜色和尺寸。 |

## BadgePosition枚举说明
Z
zengyawen 已提交
41

S
sienna1128 已提交
42
| 名称 | 描述 |
43
| -------- | -------- |
S
sienna1128 已提交
44 45 46
| RightTop | 圆点显示在右上角。 |
| Right | 圆点显示在右侧纵向居中。 |
| Left | 圆点显示在左侧纵向居中。 |
Z
zengyawen 已提交
47

S
sienna1128 已提交
48
## BadgeStyle对象说明
Z
z00797032 已提交
49 50 51 52 53 54 55

| 名称       | 类型                                       | 必填 | 默认值      | 描述                                        |
| ---------- | ------------------------------------------ | ---- | ----------- | ------------------------------------------- |
| color      | [ResourceColor](ts-types.md#resourcecolor) | 否   | Color.White | 文本颜色。                                  |
| fontSize   | number \| string                 | 否   | 10          | 文本大小,单位vp。                          |
| badgeSize  | number \| string                 | 否   | 16          | Badge的大小,单位vp。不支持百分比形式设置。 |
| badgeColor | [ResourceColor](ts-types.md#resourcecolor) | 否   | Color.Red   | Badge的颜色。                               |
Z
zengyawen 已提交
56

Z
zengyawen 已提交
57
## 示例
Z
zengyawen 已提交
58

H
geshi  
HelloCrease 已提交
59 60
```ts
// xxx.ets
Z
zengyawen 已提交
61 62 63
@Entry
@Component
struct BadgeExample {
S
sienna1128 已提交
64 65
  @State counts: number = 1;
  @State message: string = 'new';
Z
zengyawen 已提交
66 67

  build() {
S
sienna1128 已提交
68 69 70 71 72 73 74 75 76 77 78 79
    Column() {
      Text('numberBadge').width('80%')
      Row({ space: 10 }) {
        // 数字上标,maxCount默认99,超过99展示99+
        Badge({
          count: this.counts,
          maxCount: 99,
          position: BadgePosition.RightTop,
          style: { color: 0xFFFFFF, fontSize: 16, badgeSize: 20, badgeColor: Color.Red }
        }) {
          Button('message')
            .onClick(() => {
S
sienna1128 已提交
80
              this.counts++;
S
sienna1128 已提交
81 82 83 84 85 86 87 88 89 90 91 92 93
            })
            .width(100).height(50).backgroundColor(0x317aff)
        }.width(100).height(50)

        // 数字上标
        Badge({
          count: this.counts,
          maxCount: 99,
          position: BadgePosition.Left,
          style: { color: 0xFFFFFF, fontSize: 16, badgeSize: 20, badgeColor: Color.Red }
        }) {
          Button('message')
            .onClick(() => {
S
sienna1128 已提交
94
              this.counts++;
S
sienna1128 已提交
95 96 97 98 99 100 101 102 103 104 105 106 107 108
            })
            .width(100).height(50).backgroundColor(0x317aff)
        }.width(100).height(50)


        // 数字上标
        Badge({
          count: this.counts,
          maxCount: 99,
          position: BadgePosition.Right,
          style: { color: 0xFFFFFF, fontSize: 16, badgeSize: 20, badgeColor: Color.Red }
        }) {
          Button('message')
            .onClick(() => {
S
sienna1128 已提交
109
              this.counts++;
S
sienna1128 已提交
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 143 144 145 146 147
            })
            .width(100).height(50).backgroundColor(0x317aff)
        }.width(100).height(50)
      }.margin(10)

      Text('stringBadge').width('80%')
      Row({ space: 30 }) {
        Badge({
          value: this.message,
          style: { color: 0xFFFFFF, fontSize: 9, badgeSize: 20, badgeColor: Color.Blue }
        }) {
          Text('message')
            .width(80)
            .height(50)
            .fontSize(16)
            .lineHeight(37)
            .borderRadius(10)
            .textAlign(TextAlign.Center)
            .backgroundColor(0xF3F4ED)
        }.width(80).height(50)

        // value为空,设置圆点标记
        Badge({
          value: '',
          position: BadgePosition.Right,
          style: { badgeSize: 6, badgeColor: Color.Red }
        }) {
          Text('message')
            .width(90)
            .height(50)
            .fontSize(16)
            .lineHeight(37)
            .borderRadius(10)
            .textAlign(TextAlign.Center)
            .backgroundColor(0xF3F4ED)
        }.width(90).height(50)
      }.margin(10)
    }
Z
zengyawen 已提交
148 149 150 151
  }
}
```

S
sienna1128 已提交
152
![badge](figures/badge.png)