HarmonyOS API:全局UI方法
版本:v3.1 Beta
日期滑动选择器弹窗
更新时间: 2023-02-17 09:19
根据指定的日期范围创建日期滑动选择器,展示在弹窗上。
说明
该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
DatePickerDialog.show
show(options?: DatePickerDialogOptions)
定义日期滑动选择器弹窗并弹出。
DatePickerDialogOptions参数:
参数名  | 参数类型  | 必填  | 默认值  | 参数描述  | 
start  | Date  | 否  | Date('1970-1-1')  | 设置选择器的起始日期。  | 
end  | Date  | 否  | Date('2100-12-31')  | 设置选择器的结束日期。  | 
selected  | Date  | 否  | 当前系统日期  | 设置当前选中的日期。  | 
lunar  | boolean  | 否  | false  | 日期是否显示为农历。  | 
onAccept  | (value: DatePickerResult) => void  | 否  | -  | 点击弹窗中的“确定”按钮时触发该回调。  | 
onCancel  | () => void  | 否  | -  | 点击弹窗中的“取消”按钮时触发该回调。  | 
onChange  | (value: DatePickerResult) => void  | 否  | -  | 滑动弹窗中的滑动选择器使当前选中项改变时触发该回调。  | 
示例
// xxx.ets
@Entry
@Component
struct DatePickerDialogExample {
  selectedDate: Date = new Date("2010-1-1")
  build() {
    Column() {
      Button("DatePickerDialog")
        .margin(20)
        .onClick(() => {
          DatePickerDialog.show({
            start: new Date("2000-1-1"),
            end: new Date("2100-12-31"),
            selected: this.selectedDate,
            onAccept: (value: DatePickerResult) => {
              // 通过Date的setFullYear方法设置按下确定按钮时的日期,这样当弹窗再次弹出时显示选中的是上一次确定的日期
              this.selectedDate.setFullYear(value.year, value.month, value.day)
              console.info("DatePickerDialog:onAccept()" + JSON.stringify(value))
            },
            onCancel: () => {
              console.info("DatePickerDialog:onCancel()")
            },
            onChange: (value: DatePickerResult) => {
              console.info("DatePickerDialog:onChange()" + JSON.stringify(value))
            }
          })
        })
      Button("Lunar DatePickerDialog")
        .margin(20)
        .onClick(() => {
          DatePickerDialog.show({
            start: new Date("2000-1-1"),
            end: new Date("2100-12-31"),
            selected: this.selectedDate,
            lunar: true,
            onAccept: (value: DatePickerResult) => {
              this.selectedDate.setFullYear(value.year, value.month, value.day)
              console.info("DatePickerDialog:onAccept()" + JSON.stringify(value))
            },
            onCancel: () => {
              console.info("DatePickerDialog:onCancel()")
            },
            onChange: (value: DatePickerResult) => {
              console.info("DatePickerDialog:onChange()" + JSON.stringify(value))
            }
          })
        })
    }.width('100%')
  }
}
时间滑动选择器弹窗
更新时间: 2023-02-17 09:19
以24小时的时间区间创建时间滑动选择器,展示在弹窗上。
说明
该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
TimePickerDialog.show
show(options?: TimePickerDialogOptions)
定义时间滑动选择器弹窗并弹出。
TimePickerDialogOptions参数:
参数名  | 参数类型  | 必填  | 参数描述  | 
selected  | Date  | 否  | 设置当前选中的时间。 默认值:当前系统时间  | 
useMilitaryTime  | boolean  | 否  | 展示时间是否为24小时制,默认为12小时制。 默认值:false  | 
onAccept  | (value: TimePickerResult) => void  | 否  | 点击弹窗中的“确定”按钮时触发该回调。  | 
onCancel  | () => void  | 否  | 点击弹窗中的“取消”按钮时触发该回调。  | 
onChange  | (value: TimePickerResult) => void  | 否  | 滑动弹窗中的选择器使当前选中时间改变时触发该回调。  | 
示例
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
  private selectTime: Date = new Date('2020-12-25T08:30:00')
  build() {
    Column() {
      Button("TimePickerDialog 12小时制")
        .margin(20)
        .onClick(() => {
          TimePickerDialog.show({
            selected: this.selectTime,
            onAccept: (value: TimePickerResult) => {
              // 设置selectTime为按下确定按钮时的时间,这样当弹窗再次弹出时显示选中的为上一次确定的时间
              this.selectTime.setHours(value.hour, value.minute)
              console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
            },
            onCancel: () => {
              console.info("TimePickerDialog:onCancel()")
            },
            onChange: (value: TimePickerResult) => {
              console.info("TimePickerDialog:onChange()" + JSON.stringify(value))
            }
          })
        })
      Button("TimePickerDialog 24小时制")
        .margin(20)
        .onClick(() => {
          TimePickerDialog.show({
            selected: this.selectTime,
            useMilitaryTime: true,
            onAccept: (value: TimePickerResult) => {
              this.selectTime.setHours(value.hour, value.minute)
              console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
            },
            onCancel: () => {
              console.info("TimePickerDialog:onCancel()")
            },
            onChange: (value: TimePickerResult) => {
              console.info("TimePickerDialog:onChange()" + JSON.stringify(value))
            }
          })
        })
    }.width('100%')
  }
}
文本滑动选择器弹窗
更新时间: 2023-02-17 09:19
根据指定的选择范围创建文本选择器,展示在弹窗上。
说明
该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
TextPickerDialog.show
show(options?: TextPickerDialogOptions)
定义文本滑动选择器弹窗并弹出。
TextPickerDialogOptions参数:
参数名  | 参数类型  | 必填  | 参数描述  | 
range  | string[] | Resource  | 是  | 设置文本选择器的选择范围。  | 
selected  | number  | 否  | 设置选中项的索引值。 默认值:0  | 
value  | string  | 否  | 设置选中项的文本内容。当设置了selected参数时,该参数不生效。如果设置的value值不在range范围内,则默认取range第一个元素。  | 
defaultPickerItemHeight  | number | string  | 否  | 设置选择器中选项的高度。  | 
onAccept  | (value: TextPickerResult) => void  | 否  | 点击弹窗中的“确定”按钮时触发该回调。  | 
onCancel  | () => void  | 否  | 点击弹窗中的“取消”按钮时触发该回调。  | 
onChange  | (value: TextPickerResult) => void  | 否  | 滑动弹窗中的选择器使当前选中项改变时触发该回调。  | 
TextPickerResult对象说明
名称  | 类型  | 描述  | 
value  | string  | 选中项的文本内容。  | 
index  | number  | 选中项在选择范围数组中的索引值。  | 
示例
// xxx.ets
@Entry
@Component
struct TextPickerDialogExample {
  @State select: number = 2
  private fruits: string[] = ['apple1', 'orange2', 'peach3', 'grape4', 'banana5']
  build() {
    Column() {
      Button("TextPickerDialog")
        .margin(20)
        .onClick(() => {
          TextPickerDialog.show({
            range: this.fruits,
            selected: this.select,
            onAccept: (value: TextPickerResult) => {
              // 设置select为按下确定按钮时候的选中项index,这样当弹窗再次弹出时显示选中的是上一次确定的选项
              this.select = value.index
              console.info("TextPickerDialog:onAccept()" + JSON.stringify(value))
            },
            onCancel: () => {
              console.info("TextPickerDialog:onCancel()")
            },
            onChange: (value: TextPickerResult) => {
              console.info("TextPickerDialog:onChange()" + JSON.stringify(value))
            }
          })
        })
    }.width('100%')
  }
}



















