写点什么

《HarmonyOS Next 开发进阶:打造功能完备的 Todo 应用华章》

作者:The Wang
  • 2025-03-31
    湖南
  • 本文字数:2474 字

    阅读完需:约 8 分钟

章节 6:日期选择器与日期处理

目标

  • 学习如何使用DatePicker组件。

  • 理解日期格式化和日期计算。

内容

  1. 日期选择器基础

  2. 使用DatePicker组件。

  3. 处理日期选择事件。

  4. 日期格式化

  5. 格式化日期为友好的文本。

  6. 日期计算

  7. 判断日期是否过期或即将到期。

代码示例

@Entry@Componentstruct DatePickerDemo {  @State selectedDate: Date = new Date();  @State showDatePicker: boolean = false;
formatDate(date: Date): string { return `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')}`; }
build() { Column() { Text('选择日期: ' + this.formatDate(this.selectedDate)) .margin({ bottom: 16 })
Button('选择日期') .onClick(() => { this.showDatePicker = true; })
if (this.showDatePicker) { DatePicker({ start: new Date('2020-01-01'), end: new Date('2030-12-31'), selected: this.selectedDate, }) .onChange((value: DatePickerInfo) => { this.selectedDate = new Date(value.year, value.month - 1, value.day); }) .margin({ bottom: 16 }) } } }}
复制代码

章节 7:任务统计与数据可视化

目标

  • 学习如何实现任务统计。

  • 理解简单的数据可视化方法。

内容

  1. 任务统计

  2. 计算任务总数和完成率。

  3. 按优先级统计任务数量。

  4. 数据可视化

  5. 使用简单的图表展示统计数据。

  6. 示例:任务统计面板

  7. 实现任务统计功能。

代码示例

@Entry@Componentstruct TaskStatistics {  @State todoList: TodoItem[] = [    new TodoItem('任务1', Priority.HIGH),    new TodoItem('任务2', Priority.MEDIUM),    new TodoItem('任务3', Priority.LOW)  ];
getCompletionPercentage(): number { if (this.todoList.length === 0) return 0; const completedCount = this.todoList.filter(item => item.isCompleted).length; return Math.round((completedCount / this.todoList.length) * 100); }
getPriorityStats(): PriorityStatItem[] { const highStat: PriorityStatItem = { priority: Priority.HIGH, count: 0, color: '#FF3B30' }; const mediumStat: PriorityStatItem = { priority: Priority.MEDIUM, count: 0, color: '#FF9500' }; const lowStat: PriorityStatItem = { priority: Priority.LOW, count: 0, color: '#34C759' };
this.todoList.forEach(item => { switch (item.priority) { case Priority.HIGH: highStat.count++; break; case Priority.MEDIUM: mediumStat.count++; break; case Priority.LOW: lowStat.count++; break; } });
return [highStat, mediumStat, lowStat]; }
build() { Column() { Text('任务统计') .fontSize(24) .fontWeight(FontWeight.Bold) .margin({ bottom: 16 })
Text(`完成率: ${this.getCompletionPercentage()}%`) .margin({ bottom: 16 })
ForEach(this.getPriorityStats(), (stat: PriorityStatItem) => { Row() { Circle() .fill(stat.color) .width(12) .height(12) .margin({ right: 8 }) Text(`${stat.priority}: ${stat.count} 个`) } .margin({ bottom: 8 }) }) } }}
复制代码

章节 8:振动反馈与用户交互

目标

  • 学习如何使用@ohos.vibrator实现振动反馈。

  • 理解用户交互的优化方法。

内容

  1. 振动反馈基础

  2. 使用vibrate方法实现短振动。

  3. 用户交互优化

  4. 在任务操作时提供振动反馈。

  5. 示例:振动反馈应用

  6. 实现用户交互时的振动效果。

代码示例

import vibrator from '@ohos.vibrator';
@Entry@Componentstruct VibrationDemo { vibrateShort() { try { vibrator.vibrate(10); } catch (error) { console.error('Failed to vibrate:', error); } }
build() { Column() { Text('点击按钮体验振动反馈') .margin({ bottom: 16 })
Button('短振动') .onClick(() => this.vibrateShort()) } }}
复制代码

章节 9:对话框与用户提示

目标

  • 学习如何使用@ohos.promptAction显示对话框。

  • 理解如何处理用户输入。

内容

  1. 对话框基础

  2. 使用showDialog方法显示对话框。

  3. 用户输入处理

  4. 获取用户选择的结果。

  5. 示例:确认删除对话框

  6. 实现删除任务时的确认对话框。

代码示例

import promptAction from '@ohos.promptAction';
@Entry@Componentstruct DialogDemo { async showConfirmationDialog() { try { const dialogButtons: Array<DialogButton> = [ { text: '取消', color: '#8E8E93' }, { text: '确定', color: '#FF3B30' } ];
const options: promptAction.ShowDialogOptions = { title: '确认删除', message: '确定要删除此任务吗?', buttons: dialogButtons };
const result = await promptAction.showDialog(options); if (result && result.index === 1) { console.log('用户确认删除'); } } catch (error) { console.error('对话框显示失败:', error); } }
build() { Column() { Text('点击按钮显示对话框') .margin({ bottom: 16 })
Button('删除任务') .onClick(() => this.showConfirmationDialog()) } }}
复制代码

章节 10:完整 Todo 应用实现

目标

  • 综合应用前面章节的知识,实现一个完整的 Todo 应用。

  • 理解如何将各个功能模块整合在一起。

内容

  1. 功能整合

  2. 数据存储与加载。

  3. 响应式布局与主题切换。

  4. 任务管理与统计。

  5. 日期选择与振动反馈。

  6. 完整代码实现

  7. 从头到尾实现一个功能完整的 Todo 应用。

代码示例

(完整代码见用户提供的代码)

用户头像

The Wang

关注

还未添加个人签名 2024-07-19 加入

还未添加个人简介

评论

发布
暂无评论
《HarmonyOS Next开发进阶:打造功能完备的Todo应用华章》_HarmonyOS NEXT_The Wang_InfoQ写作社区