TimePicker

滑动选择时间的组件。

说明:

  • 该组件从API version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。

  • 该组件不建议开发者在动效过程中修改属性数据。

  • 最大显示行数在横、竖屏模式下存在差异。竖屏时默认为5行,横屏时依赖系统配置,未配置时默认显示为3行。可通过如下参数查看具体配置值$r('sys.float.ohos_id_picker_show_count_landscape')。

子组件

该组件为基础组件,不建议包含子组件。

接口

TimePicker(options?: TimePickerOptions)

创建滑动选择器,默认使用24小时的时间区间。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
options TimePickerOptions 配置时间选择组件的参数。

TimePickerOptions对象说明

时间选择器组件的参数说明。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 只读 可选 说明
selected Date 设置选中项的时间。
默认值:当前系统时间
从API version 10开始,该参数支持$$双向绑定变量。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
format11+ TimePickerFormat 指定需要显示的TimePicker的格式。
默认值:TimePickerFormat.HOUR_MINUTE
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
模型约束: 此接口仅可在Stage模型下使用。
start18+ Date 指定时间选择组件的起始时间。
默认值:Date(0, 0, 0, 0, 0, 0)
说明:
1. 仅设置的小时和分钟生效。
2. 设置了start且为非默认值的场景下,loop不生效。
原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。
模型约束: 此接口仅可在Stage模型下使用。
end18+ Date 指定时间选择组件的结束时间。
默认值:Date(0, 0, 0, 23, 59, 59)
说明:
1. 仅设置的小时和分钟生效。
2. 设置了end且为非默认值的场景下,loop不生效。
原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。
模型约束: 此接口仅可在Stage模型下使用。

在TimePicker组件滑动过程中修改TimePickerOptions中的属性,会导致这些属性无法生效。

Date对象用于处理日期和时间,使用方式如下。

方式1: new Date()

获取系统当前日期和时间。

方式2: new Date(value: number | string)

参数名 类型 必填 说明
value number | string 设置日期格式。
number:毫秒,自1970年1月1日00:00:00开始的毫秒数。
string:时间格式的字符串,如‘2025-02-20 08:00:00’或‘2025-02-20T08:00:00’。

方式3: new Date(year: number, monthIndex: number, date?: number, hours?: number, minutes?: number, seconds?: number, ms?: number)

参数名 类型 必填 说明
year number 设置年份,例如2025。
monthIndex number 设置月份索引,例如2,代表3月份。
date number 设置日期,例如10(如果设置hours,则date不能省略)。
hours number 设置小时,例如15(如果设置minutes,则hours不能省略)。
minutes number 设置分钟,例如20(如果设置seconds,则minutes不能省略)。
seconds number 设置秒,例如20(如果设置ms,则seconds不能省略)。
ms number 设置毫秒,例如10。

起始时间和结束时间的异常情形说明:

异常情形 对应结果
起始时间晚于结束时间。 起始时间、结束时间都为默认值。
选中时间早于起始时间。 选中时间为起始时间。
选中时间晚于结束时间。 选中时间为结束时间。
起始时间晚于当前系统时间,选中时间未设置。 选中时间为起始时间。
结束时间早于当前系统时间,选中时间未设置。 选中时间为结束时间。
时间格式不符合规范,如'01:61:61'。 取默认值。

TimePickerFormat11+枚举说明

时间选择器的数据格式。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 说明
HOUR_MINUTE 0 按照小时和分钟进行显示。
HOUR_MINUTE_SECOND 1 按照小时、分钟和秒进行显示。

属性

除支持通用属性外,还支持以下属性:

useMilitaryTime

useMilitaryTime(value: boolean)

设置时间是否以24小时制展示,未通过该接口设置时,默认跟随系统设置展示。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 时间是否以24小时制展示。
- true:时间以24小时制展示。
- false:时间以12小时制展示。

useMilitaryTime18+

useMilitaryTime(isMilitaryTime: Optional<boolean>)

设置展示时间是否为24小时制,未通过该接口设置时,默认跟随系统设置展示。与useMilitaryTime相比,isMilitaryTime参数新增了对undefined类型的支持。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
isMilitaryTime Optional<boolean> 展示时间是否为24小时制。
- true:展示时间为24小时制。
- false:展示时间为12小时制。
当isMilitaryTime的值为undefined时,跟随系统设置。

disappearTextStyle10+

disappearTextStyle(value: PickerTextStyle)

设置边缘项(以选中项为基准向上或向下的第二项)的文本颜色、字号、字体粗细。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value PickerTextStyle 边缘项的文本颜色、字号和字体粗细。
默认值:
{
color: '#ff182431',
font: {
size: '14fp',
weight: FontWeight.Regular
}
}

说明:

若选中项向上或向下的可视项数低于两项则无对应边缘项。

disappearTextStyle18+

disappearTextStyle(style: Optional<PickerTextStyle>)

设置边缘项(以选中项为基准向上或向下的第二项)的文本颜色、字号、字体粗细。与disappearTextStyle10+相比,style参数新增了对undefined类型的支持。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
style Optional<PickerTextStyle> 边缘项的文本颜色、字号、字体粗细。
默认值:
{
color: '#ff182431',
font: {
size: '14fp',
weight: FontWeight.Regular
}
}
当style的值为undefined时,使用默认值。

说明:

若选中项向上或向下的可视项数低于两项则无对应边缘项。

textStyle10+

textStyle(value: PickerTextStyle)

设置待选项(以选中项为基准向上或向下的第一项)的文本颜色、字号、字体粗细。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value PickerTextStyle 待选项的文本颜色、字号、字体粗细。
默认值:
{
color: '#ff182431',
font: {
size: '16fp',
weight: FontWeight.Regular
}
}

说明:

若选中项向上或向下可视项数低于一项则无对应待选项。

textStyle18+

textStyle(style: Optional<PickerTextStyle>)

设置待选项(以选中项为基准向上或向下的第一项)的文本颜色、字号、字体粗细。与textStyle10+相比,style参数新增了对undefined类型的支持。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
style Optional<PickerTextStyle> 待选项的文本颜色、字号、字体粗细。
默认值:
{
color: '#ff182431',
font: {
size: '16fp',
weight: FontWeight.Regular
}
}
当style的值为undefined时,使用默认值。

说明:

若选中项向上或向下可视项数低于一项则无对应待选项。

selectedTextStyle10+

selectedTextStyle(value: PickerTextStyle)

设置选中项的文本颜色、字号和字体粗细。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

设备行为差异: 该属性在Wearable设备上使用无效果,在其他设备中可正常生效。

参数:

参数名 类型 必填 说明
value PickerTextStyle 选中项的文本颜色、字号、字体粗细。
默认值:
{
color: '#ff007dff',
font: {
size: '20fp',
weight: FontWeight.Medium
}
}

selectedTextStyle18+

selectedTextStyle(style: Optional<PickerTextStyle>)

设置选中项的文本颜色、字号及字体粗细。与selectedTextStyle10+相比,style参数新增了对undefined类型的支持。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

设备行为差异: 该属性在Wearable设备上使用无效果,在其他设备中可正常生效。

参数:

参数名 类型 必填 说明
style Optional<PickerTextStyle> 选中项的文本颜色、字号、字体粗细。
默认值:
{
color: '#ff007dff',
font: {
size: '20fp',
weight: FontWeight.Medium
}
}
当style的值为undefined时,使用默认值。

loop11+

loop(value: boolean)

设置是否启用循环模式。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 是否启用循环模式。
- true:启用循环模式。
- false:不启用循环模式。
默认值:true

loop18+

loop(isLoop: Optional<boolean>)

设置是否启用循环模式。与loop11+相比,isLoop参数新增了对undefined类型的支持。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
isLoop Optional<boolean> 是否启用循环模式。
- true:启用循环模式。
- false:不启用循环模式。
默认值:true
当isLoop的值为undefined时,使用默认值。

dateTimeOptions12+

dateTimeOptions(value: DateTimeOptions)

设置时分秒是否显示前导0。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value DateTimeOptions 设置时分秒是否显示前导0。
默认值:
hour: 24小时制默认为"2-digit",设置hour是否按照2位数字显示,如果实际数值小于10,则会补充前导0并显示,即为"0X";12小时制默认为"numeric",即没有前导0。
minute: 默认为"2-digit",设置minute是否按照2位数字显示,如果实际数值小于10,则会补充前导0并显示,即为"0X"。
second: 默认为"2-digit",设置second是否按照2位数字显示,如果实际数值小于10,则会补充前导0并显示,即为"0X"。
当hour、minute、second的值设置为undefined时,显示效果与其默认值规则一致。

dateTimeOptions18+

dateTimeOptions(timeFormat: Optional<DateTimeOptions>)

设置时分秒是否显示前导0。与dateTimeOptions12+相比,timeFormat参数新增了对undefined类型的支持。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
timeFormat Optional<DateTimeOptions> 设置时分秒是否显示前导0,目前只支持设置hour、minute和second参数。
默认值:
hour: 24小时制默认为"2-digit",设置hour是否按照2位数字显示,如果实际数值小于10,则会补充前导0并显示,即为"0X";12小时制默认为"numeric",即没有前导0。
minute: 默认为"2-digit",设置minute是否按照2位数字显示,如果实际数值小于10,则会补充前导0并显示,即为"0X"。
second: 默认为"2-digit",设置second是否按照2位数字显示,如果实际数值小于10,则会补充前导0并显示,即为"0X"。
当hour、minute、second的值设置为undefined时,显示效果与其默认值规则一致。

enableHapticFeedback12+

enableHapticFeedback(enable: boolean)

设置是否支持触控反馈。

开启触控反馈时,需要在工程的src/main/module.json5文件的"module"内配置requestPermissions字段开启振动权限,配置如下:

"requestPermissions": [
   {
      "name": "ohos.permission.VIBRATE",
   }
]

说明:

从API version 18开始,该接口支持在attributeModifier中调用。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
enable boolean 设置是否开启触控反馈。
- true:开启触控反馈。
- false:不开启触控反馈。
默认值:true
设置为true后,其生效情况取决于系统的硬件是否支持。

enableHapticFeedback18+

enableHapticFeedback(enable: Optional<boolean>)

设置是否支持触控反馈。与enableHapticFeedback12+相比,enable参数新增了对undefined类型的支持。

开启触控反馈时,需要在工程的src/main/module.json5文件的"module"内配置requestPermissions字段开启振动权限,配置如下:

"requestPermissions": [
  {
    "name": "ohos.permission.VIBRATE",
  }
]

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
enable Optional<boolean> 设置是否开启触控反馈。
- true:开启触控反馈。
- false:不开启触控反馈。
默认值:true
当enable的值为undefined时,使用默认值。
设置为true后,其生效情况取决于系统的硬件是否支持。

enableCascade18+

enableCascade(enabled: boolean)

设置上午和下午的标识是否根据小时数自动切换,仅在useMilitaryTime设置为false时生效。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
enabled boolean 上午和下午的标识是否根据小时数自动切换,仅在useMilitaryTime设置为false时生效。
- true:自动切换。
- false:不自动切换。
默认值:false
当enabled设置为true时,仅在loop参数同时为true时生效。

digitalCrownSensitivity18+

digitalCrownSensitivity(sensitivity: Optional<CrownSensitivity>)

设置表冠灵敏度。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
sensitivity Optional<CrownSensitivity> 表冠响应灵敏度。
默认值:CrownSensitivity.MEDIUM,表示响应速度适中。

说明:

用于圆形屏幕的穿戴设备。组件响应表冠事件,需要先获取焦点。

事件

除支持通用事件外,还支持以下事件:

onChange

onChange(callback: (value: TimePickerResult ) => void)

滑动TimePicker后,时间选项归位至选中项位置时,触发该回调。不能通过双向绑定的状态变量触发。

回调会在滑动动画结束后触发,如果需要快速获取索引值变化,建议使用onEnterSelectedArea接口。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value TimePickerResult 24小时制时间。

onChange18+

onChange(callback: Optional<OnTimePickerChangeCallback>)

滑动TimePicker后,时间选项归位至选中项位置时,触发该回调。不能通过双向绑定的状态变量触发。与onChange相比,callback参数新增了对undefined类型的支持。

回调会在滑动动画结束后触发,如果需要快速获取索引值变化,建议使用onEnterSelectedArea接口。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Optional<OnTimePickerChangeCallback> 选择时间时触发该回调。
当callback的值为undefined时,不使用回调函数。

onEnterSelectedArea18+

onEnterSelectedArea(callback: Callback<TimePickerResult>)

滑动TimePicker过程中,选项进入分割线区域内,触发该回调。

onChange事件的差别在于,该事件的触发时机早于onChange事件,当当前滑动列滑动距离超过选中项高度的一半时,选项此时已经进入分割线区域内,会触发该事件。当enableCascade设置为true时,由于上午/下午列与小时列存在联动关系,不建议使用该回调。该回调标识的是滑动过程中选项进入分割线区域内的节点,而联动变化的选项并不涉及滑动,因此,回调的返回值中,仅当前滑动列的值会正常变化,其余未滑动列的值保持不变。

说明:

该接口不支持在attributeModifier中调用。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Callback<TimePickerResult> 滑动TimePicker过程中,选项进入分割线区域时触发的回调。

DateTimeOptions12+类型说明

type DateTimeOptions = DateTimeOptions

时间、日期格式化时可设置的配置项。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

类型 说明
DateTimeOptions 创建时间、日期格式化对象时可设置的配置项。

OnTimePickerChangeCallback18+

type OnTimePickerChangeCallback = (result: TimePickerResult) => void

选择时间时触发该事件。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

模型约束: 此接口仅可在Stage模型下使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
result TimePickerResult 24小时制时间。

TimePickerResult对象说明

返回24小时制时间。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 只读 可选 说明
hour number 选中时间的时。
取值范围:[0-23]
minute number 选中时间的分。
取值范围:[0-59]
second11+ number 选中时间的秒。
取值范围:[0-59]
模型约束: 此接口仅可在Stage模型下使用。

示例

示例1(设置文本样式)

该示例通过配置disappearTextStyletextStyleselectedTextStyle实现文本选择器中的文本样式。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  private selectedTime: Date = new Date('2022-07-22T08:00:00');

  build() {
    TimePicker({
      selected: this.selectedTime
    })
      .disappearTextStyle({ color: '#004aaf', font: { size: 24, weight: FontWeight.Lighter } })
      .textStyle({ color: Color.Black, font: { size: 26, weight: FontWeight.Normal } })
      .selectedTextStyle({ color: Color.Blue, font: { size: 30, weight: FontWeight.Bolder } })
      .onChange((value: TimePickerResult) => {
        if (value.hour >= 0) {
          this.selectedTime.setHours(value.hour, value.minute);
          console.info('select current date is: ' + JSON.stringify(value));
        }
      })
  }
}

timePicker

示例2(切换小时制)

该示例通过配置useMilitaryTime实现12小时制、24小时制的切换。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  @State isMilitaryTime: boolean = false;
  private selectedTime: Date = new Date('2022-07-22T08:00:00');

  build() {
    Column() {
      Button('切换12小时制/24小时制')
        .margin(30)
        .onClick(() => {
          this.isMilitaryTime = !this.isMilitaryTime;
        })

      TimePicker({
        selected: this.selectedTime
      })
        .useMilitaryTime(this.isMilitaryTime)
        .onChange((value: TimePickerResult) => {
          if (value.hour >= 0) {
            this.selectedTime.setHours(value.hour, value.minute);
            console.info('select current time is: ' + JSON.stringify(value));
          }
        })
        .onEnterSelectedArea((value: TimePickerResult) => {
            console.info('item enter selected area, time is: ' + JSON.stringify(value));
        })
    }.width('100%')
  }
}

timePicker

示例3(设置时间格式)

该示例使用format和dateTimeOptions设置TimePicker时间格式。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  private selectedTime: Date = new Date('2022-07-22T08:00:00');

  build() {
    Column() {
      TimePicker({
        selected: this.selectedTime,
        format: TimePickerFormat.HOUR_MINUTE_SECOND
      })
        .dateTimeOptions({ hour: "numeric", minute: "2-digit", second: "2-digit" })
        .onChange((value: TimePickerResult) => {
          if (value.hour >= 0) {
            this.selectedTime.setHours(value.hour, value.minute);
            console.info('select current date is: ' + JSON.stringify(value));
          }
        })
    }.width('100%')
  }
}

timePicker

示例4(设置循环滚动)

该示例通过配置loop设置TimePicker是否循环滚动。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  @State isLoop: boolean = true;
  @State selectedTime: Date = new Date('2022-07-22T12:00:00');

  build() {
    Column() {
      TimePicker({
        selected: this.selectedTime
      })
        .loop(this.isLoop)
        .onChange((value: TimePickerResult) => {
          if (value.hour >= 0) {
            this.selectedTime.setHours(value.hour, value.minute);
            console.info('select current date is: ' + JSON.stringify(value));
          }
        })

      Row() {
        Text('循环滚动').fontSize(20)

        Toggle({ type: ToggleType.Switch, isOn: true })
          .onChange((isOn: boolean) => {
            this.isLoop = isOn;
          })
      }.position({ x: '60%', y: '40%' })

    }.width('100%')
  }
}

timePicker

示例5(设置时间选择组件的起始时间)

该示例设置TimePicker的起始时间。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  private selectedTime: Date = new Date('2022-07-22T08:50:00');

  build() {
    Column() {
      TimePicker({
        selected: this.selectedTime,
        format: TimePickerFormat.HOUR_MINUTE_SECOND,
        start: new Date('2022-07-22T08:30:00')
      })
        .dateTimeOptions({ hour: "numeric", minute: "2-digit", second: "2-digit" })
        .onChange((value: TimePickerResult) => {
          if (value.hour >= 0) {
            this.selectedTime.setHours(value.hour, value.minute);
            console.info('select current date is: ' + JSON.stringify(value));
          }
        })
    }.width('100%')
  }
}

timePicker

示例6(设置时间选择组件的结束时间)

该示例设置TimePicker的结束时间。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  private selectedTime: Date = new Date('2022-07-22T08:50:00');

  build() {
    Column() {
      TimePicker({
        selected: this.selectedTime,
        format: TimePickerFormat.HOUR_MINUTE_SECOND,
        end: new Date('2022-07-22T15:20:00'),
      })
        .dateTimeOptions({ hour: "numeric", minute: "2-digit", second: "2-digit" })
        .onChange((value: TimePickerResult) => {
          if (value.hour >= 0) {
            this.selectedTime.setHours(value.hour, value.minute);
            console.info('select current date is: ' + JSON.stringify(value));
          }
        })
    }.width('100%')
  }
}

timePicker

示例7(设置上午下午跟随时间联动)

该示例通过配置enableCascadeloop实现12小时制时上午下午跟随时间联动。

从API version 18开始,新增enableCascade接口。

// xxx.ets
@Entry
@Component
struct TimePickerExample {
  private selectedTime: Date = new Date('2022-07-22T08:00:00');

  build() {
    Column() {
      TimePicker({
        selected: this.selectedTime,
      })
        .enableCascade(true)
        .loop(true)
        .onChange((value: TimePickerResult) => {
          if (value.hour >= 0) {
            this.selectedTime.setHours(value.hour, value.minute);
            console.info('select current date is: ' + JSON.stringify(value));
          }
        })
    }.width('100%')
  }
}

timePicker