HarmonyOS Next 办公应用:业务页面核心功能实现(一)

HarmonyOS Next 办公应用:业务页面核心功能实现

概述

在 HarmonyOS Next 办公类应用开发中,业务页面的构建是关键环节,它需集成多种办公功能,为用户提供便捷的操作体验。下面将介绍如何构建一个包含日历、打卡、待办审批等功能的业务页面。

核心代码功能及对应代码段

1. 打卡功能

该功能用于记录用户的打卡时间,并在界面上显示首次和末次打卡时间。

typescript 复制代码
ClockIn(){
  setTimeout(()=>{
    this.getCurrentTime()
    promptAction.showToast({
      message:'打卡成功',
      duration:500
    })
  },500)
}

getCurrentTime(){
  let currentDateTime = new Date();
  let currentHour = currentDateTime.getHours();
  let currentMinute = currentDateTime.getMinutes();
  let currentSecond = currentDateTime.getSeconds();
  let currentTime = ``
  if(currentHour<=9){
    currentTime = `0${currentHour}`
  }else{
    currentTime = `${currentHour}`
  }
  if(currentMinute<=9){
    currentTime = `${currentTime}:0${currentMinute}`
  }else{
    currentTime = `${currentTime}:${currentMinute}`
  }
  if(currentSecond<=9){
    currentTime = `${currentTime}:0${currentSecond}`
  }else{
    currentTime = `${currentTime}:${currentSecond}`
  }
  let obj:ClockTimeInfo = new ClockTimeInfo(currentTime,currentHour,currentMinute,currentSecond)
  if(this.clockArr.length <=1){
    this.clockArr.push(obj)
  }else{
    this.clockArr[1] = obj
  }
}

ClockIn 方法中,通过 setTimeout 模拟打卡延迟,调用 getCurrentTime 方法获取当前时间并存储打卡记录,同时使用 promptAction.showToast 提示用户打卡成功。getCurrentTime 方法负责格式化当前时间,并将其存储在 clockArr 数组中。

2. 应用功能跳转

该功能实现了点击不同的应用模块,跳转到相应的页面。

typescript 复制代码
goToPage(type:number){
  let url = ''
  if(type===1){ //日历
    url = 'CalendarPage'
    this.pageInfos.pushPathByName(url,'')
    this.reminderService.addReminder({id: 1, hour: 10, minute: 30});
  }else if(type===2){ //手机打卡
    url = 'ClockInPage'
    let params = new NavInfo('手机打卡',JSON.stringify(this.clockArr))
    this.pageInfos.pushPathByName(url,params)
  }else if(type===3){ //待办审批
    url = 'ToDoPage'
    this.pageInfos.pushPathByName(url,'')
  }
}

goToPage 方法根据传入的 type 参数,判断用户点击的应用模块,然后使用 pageInfos.pushPathByName 方法跳转到相应的页面,并在跳转日历页面时添加提醒。

相关推荐
盐焗西兰花4 小时前
鸿蒙学习实战之路-Reader Kit修改翻页方式字体大小及行间距最佳实践
学习·华为·harmonyos
lbb 小魔仙8 小时前
【HarmonyOS实战】React Native 表单实战:在 OpenHarmony 上构建高性能表单
react native·华为·harmonyos
一只大侠的侠11 小时前
React Native开源鸿蒙跨平台训练营 Day16自定义 useForm 高性能验证
flutter·开源·harmonyos
早點睡39012 小时前
高级进阶 React Native 鸿蒙跨平台开发:@react-native-community-slider 滑块组件
react native·react.js·harmonyos
一只大侠的侠12 小时前
Flutter开源鸿蒙跨平台训练营 Day11从零开发商品详情页面
flutter·开源·harmonyos
一只大侠的侠12 小时前
React Native开源鸿蒙跨平台训练营 Day18自定义useForm表单管理实战实现
flutter·开源·harmonyos
一只大侠的侠12 小时前
React Native开源鸿蒙跨平台训练营 Day20自定义 useValidator 实现高性能表单验证
flutter·开源·harmonyos
听麟13 小时前
HarmonyOS 6.0+ 跨端智慧政务服务平台开发实战:多端协同办理与电子证照管理落地
笔记·华为·wpf·音视频·harmonyos·政务
前端世界14 小时前
从单设备到多设备协同:鸿蒙分布式计算框架原理与实战解析
华为·harmonyos
一只大侠的侠15 小时前
Flutter开源鸿蒙跨平台训练营 Day12从零开发通用型登录页面
flutter·开源·harmonyos