鸿蒙:PickerDialog 日期选择弹窗实现流程

1、前言

本文将以「日期选择弹窗」为例,参考官方文档学习与实践,并动手打造一个练手页面。

2、功能目标

  1. 页面显示标题、当前选中日期文本​
  2. 点击按钮弹出日期选择弹窗​
  3. 选择日期后,页面文本实时更新,控制台打印选中日期​
  4. 自定义弹窗确认 / 取消按钮的样式(颜色、圆角、背景等)

核心代码

复制代码
 // 8. 显示日期选择器弹窗
            CalendarPickerDialog.show({
              selected: this.selectedDate, // 9. 弹窗初始选中的日期,使用已保存的选中日期
              // 10. 确认按钮样式配置
              acceptButtonStyle: {
                fontColor: '#2787d9', // 文字颜色
                fontSize: '16fp', // 文字大小
                backgroundColor: '#f7f7f7', // 背景色
                borderRadius: 10 // 圆角半径
              },
              // 11. 取消按钮样式配置
              cancelButtonStyle: {
                fontColor: Color.Red, // 文字颜色(使用系统提供的红色)
                fontSize: '16fp', // 文字大小
                backgroundColor: '#f7f7f7', // 背景色
                borderRadius: 10, // 圆角半径,

              },
              // 12. 确认选择回调:用户点击确认按钮时触发
              onAccept: (date: Date) => {
                // 更新选中日期为用户新选择的日期,确保下次弹窗显示最新选中值
                this.selectedDate = date;
                // 打印选中的日期到控制台
                console.log('选择的日期是', this.formatDate(this.selectedDate))
              }
            })

3、参考文档

https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/arkts-fixes-style-dialog#%E9%80%89%E6%8B%A9%E5%99%A8%E5%BC%B9%E7%AA%97-pickerdialoghttps://developer.huawei.com/consumer/cn/doc/harmonyos-guides/arkts-fixes-style-dialog#%E9%80%89%E6%8B%A9%E5%99%A8%E5%BC%B9%E7%AA%97-pickerdialog

4、运行效果图

5、Index.ets完整代码

复制代码
// 选择器弹窗 (PickerDialog)练习代码
// 官方文档链接:
// https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/arkts-fixes-style-dialog#%E9%80%89%E6%8B%A9%E5%99%A8%E5%BC%B9%E7%AA%97-pickerdialog

// 1. 组件装饰器:@Entry表示该组件为应用入口组件,@Component表示这是一个ArkUI组件
@Entry
@ComponentV2
struct Index {
  // 2. 成员变量:用于存储用户选中的日期,初始值设为2025-09-27
  @Local selectedDate: Date = new Date('2025-09-27');

  // 格式化日期为 'yyyy-MM-dd' 格式的函数
  formatDate(date: Date): string {
    const year = date.getFullYear(); // 获取年份(4位数字)
    const month = date.getMonth() + 1; // 获取月份(0-11),加1转为实际月份(1-12)
    const day = date.getDate(); // 获取日期(1-31)

    // 月份和日期不足两位时补0,再拼接成字符串
    return `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;
  }

  // 3. 构建UI界面的方法,所有UI元素都在该方法中定义
  build() {
    // 4.  Column容器:垂直方向排列子组件,宽度占满屏幕
    Column() {
      Row()
        .height(30)
      Text("选择器弹窗 (PickerDialog)\n练习示例")
        .textAlign(TextAlign.Center)
        .fontWeight(FontWeight.Bold)
        .fontSize(24)
        .padding({ bottom: 200 })

      Column() {

        Text("选择的日期是:" + this.formatDate(this.selectedDate))
          .fontSize(20)
          .fontWeight(FontWeight.Bold)
        // 5. 按钮组件:用于触发日期选择器弹窗的显示
        Button("开启日期选择器弹窗")
          .margin(20) // 6. 按钮外边距:上下左右各20vp
          .onClick(() => { // 7. 点击事件:按钮被点击时执行的逻辑
            // 8. 显示日期选择器弹窗
            CalendarPickerDialog.show({
              selected: this.selectedDate, // 9. 弹窗初始选中的日期,使用已保存的选中日期
              // 10. 确认按钮样式配置
              acceptButtonStyle: {
                fontColor: '#2787d9', // 文字颜色
                fontSize: '16fp', // 文字大小
                backgroundColor: '#f7f7f7', // 背景色
                borderRadius: 10 // 圆角半径
              },
              // 11. 取消按钮样式配置
              cancelButtonStyle: {
                fontColor: Color.Red, // 文字颜色(使用系统提供的红色)
                fontSize: '16fp', // 文字大小
                backgroundColor: '#f7f7f7', // 背景色
                borderRadius: 10, // 圆角半径,

              },
              // 12. 确认选择回调:用户点击确认按钮时触发
              onAccept: (date: Date) => {
                // 更新选中日期为用户新选择的日期,确保下次弹窗显示最新选中值
                this.selectedDate = date;
                // 打印选中的日期到控制台
                console.log('选择的日期是', this.formatDate(this.selectedDate))
              }
            })
          })
      }

    }.width('100%') // 13. 设置Column容器宽度为100%(占满屏幕宽度)

    .height('100%')
  }
}
相关推荐
ITUnicorn8 小时前
【HarmonyOS6】ArkTS 自定义组件封装实战:动画水杯组件
华为·harmonyos·arkts·鸿蒙·harmonyos6
小镇敲码人8 小时前
探索华为CANN框架中的ACL仓库
c++·python·华为·acl·cann
全栈探索者9 小时前
@Component + struct = 你的新函数组件——React 开发者的鸿蒙入门指南(第 2 期)
react·harmonyos·arkts·前端开发·deveco studio·鸿蒙next·函数组件
廖松洋(Alina)9 小时前
【收尾以及复盘】flutter开发鸿蒙APP之成就徽章页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)10 小时前
【收尾以及复盘】flutter开发鸿蒙APP之打卡日历页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)10 小时前
【收尾以及复盘】flutter开发鸿蒙APP之本月数据统计页面
flutter·华为·开源·harmonyos·鸿蒙
果粒蹬i10 小时前
【HarmonyOS】DAY8:React Native for OpenHarmony 实战:多端响应式布局与高可用交互设计
react native·交互·harmonyos
讯方洋哥19 小时前
HarmonyOS App开发——职前通应用App开发(下)
华为·harmonyos
摘星编程21 小时前
React Native鸿蒙版:Image图片占位符
react native·react.js·harmonyos
大雷神21 小时前
HarmonyOS智慧农业管理应用开发教程--高高种地-- 第30篇:设置与帮助系统
harmonyos