前言
最近在日常鴻蒙開發過程中,經常會使用一些時間選擇器,鴻蒙官方提供的時間選擇器滿足不了需求,所以自己動手自定義一些經常會使用到的時間選擇器,希望能幫到你,建議點贊收藏!
實現效果

需求分析
- 默認選中日期為當前時間。
- 支持精確到時分。
- 注意閏年的計算。
技術實現
- 首先要想實現時間選擇器,需要使用一個上下可以滾動的控件,這里使用鴻蒙官方提供的 TextPicker,TextPicker 控件支持內容的上下滾動,可以用來顯示年月日的選擇器,確定了控件后,先計算日期。
new Promise< string[] >(async (resolve: (data: Array< string >) = > void, reject) = > {
let list: Array< string > = []
for (let start = this.currentYear; start <= this.currentYear + 1; start++) {
//月份
for (let i = (start == this.currentYear?this.startMonth:1); i < 13; i++) {
let day: number = 0
if (i == 1 || i == 3 || i == 5 || i == 7 || i == 8 || i == 10 || i == 12) {
day = 31
} else if (i == 2) {
//閏年
if (start % 400 == 0 || (start % 4 == 0 && start % 100 > 0)) {
day = 29
}
// //平年
else {
day = 28
}
} else {
day = 30
}
for (let j = ((start == this.currentYear&& i == this.startMonth)?this.startDay:1); j <= day; j++) {
list.push(start + "-" + (i).toString().padStart(2,"0") + "-" + j.toString().padStart(2,"0"))
}
}
}
resolve(list)
}).then((result: Array< string >) = > {
this.timeList = result
})
由于計算日期是比較耗時的操作,這里使用 Pormise 處理日期的計算,特別需要注意閏年的日期計算,這里以 1 年為周期。
- 根據計算得到的日期數據集合,使用 TextPicker 顯示年月日,同時默認選中當前時間 choseDay。
TextPicker({ range: this.timeList, value: this.choseDay })
.pickerStyle()
.onChange((value, index) = > {
this.choseDay = value.toString()
})
.width(105)
- 計算時分數據。
for (let i = 0; i < 60; i=i+this.skipMinute) {
this.minuteList.push((i< 10?"0"+i:i).toString().concat(this.isShowUnit?"分":""))
}
for (let i = 0; i < 24; i++) {
this.hourList.push((i< 10?"0"+i:i).toString().concat(this.isShowUnit?"時":""))
}
- 分別使用 TextPicker 顯示時分。
TextPicker({
range: this.hourList,
value:this.currentHour+""
}).pickerStyle()
.onChange((value,index)= >{
this.selectHour = value+""
this.onChange(this.selectHour.concat(":"+this.selectMinute))
})
TextPicker({
range: this.minuteList,
value:this.currentMinute+""
}).pickerStyle()
.onChange((value,index)= >{
this.selectMinute = value.toString()
this.onChange(this.selectHour+":"+value)
})
- 要讓時間選擇器默認選擇當前時間時,需要注意選擇器的格式為"2012-01-01",需要在計算時不足 10 時補 0。否則時間選擇器不會默認選中當前時間。
- 鴻蒙官方的 Date 類默認提供的月份是從 0 開始的,也就是說通過 data.getUTCMoth()獲取的月份默認范圍為 [0,11],而選擇器需要顯示的是 [1,12],這里需要手動處理。
總結
自定義時間選擇器看似簡單,其實需要注意的地方不少,時間的計算,時間的顯示格式,默認選中當前時間等。都需要開發者在日常開發中注意計算細節。看到這里相信你已經學會了怎么自定義一個時間選擇器了,快去動手試試吧!
審核編輯 黃宇
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
HarmonyOS
+關注
關注
80文章
2153瀏覽量
36041
發布評論請先 登錄
相關推薦
熱點推薦
電能質量監測裝置可自定義監測時段嗎?
電能質量監測裝置普遍支持自定義監測時段,現代中高端裝置還具備分時差異化監測與靈活觸發能力,可按時間、事件或混合策略定制采集與存儲,兼顧精度、效率與存儲成本。 一、自定義監測時段的核心實現方式 1.
如何保證電能質量在線監測裝置的自定義監測時段功能的準確性和穩定性?
要保證電能質量在線監測裝置 自定義監測時段功能 的準確性(時段執行精準、數據采集可靠)和穩定性(長期無故障、異常自動恢復),需從 時間基準、硬件保障、軟件調度、配置校驗、容錯冗余、運維校準 六個維度
電能質量在線監測裝置的自定義監測時段功能有哪些應用場景?
電能質量在線監測裝置的 自定義監測時段功能 ,核心價值是通過 “按需配置監測時間、采樣頻率和數據策略”,實現精準監測、資源優化與數據針對性分析,其應用場景覆蓋工業生產、商業運營、電網運維、特殊保障等
電能質量在線監測裝置可自定義監測時段嗎?
存儲策略及周期性重復規則,滿足不同場景下的監測需求。 一、自定義監測時段的核心能力 能力類型 具體說明 典型應用 基礎時段設置 設定單次監測的開始時間(精確到秒)、結束時間或持續時長 特定設備投運測試(如新增變頻
無圖形界面模式下自定義檢查工具的應用
此前文章已介紹 ANSA 中的自定義檢查工具。本文將探討該功能在無圖形界面(No-GUI)模式下的應用,旨在滿足標準化工作流程的需求,適用于需要高度自動化的前處理場景。通過集成自定義檢查,用戶可實現工作流程的高效自動化運行。
采用匯編指示符來使用自定義指令
、采用.insn匯編指示符實現risc-v自定義指令。這種方式可以指定工具來選擇寄存器,也可以自己選定寄存器。指令格式如下(引自gnu 匯編器
發表于 10-28 06:02
LOTO示波器自定義解碼功能—CANFD解碼
LOTO示波器軟件更新了自定義解碼功能,并在bilibili上傳了演示視頻,視頻鏈接: https://www.bilibili.com/video/BV1wq3ezjEjQ
HarmonyOS實戰:3秒實現一個自定義輪播圖
那么簡單,需要考慮的細節很多。不過在 HarmonyOS 中實現一個輪播圖卻是十分的簡單,本篇文章教你在最短的時間內快速實現一個自定義的 輪播圖,建議點贊收藏!
KiCad 中的自定義規則(KiCon 演講)
“ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規則系統,并詳細講解了自定義規則的設計與實例。? ” ? 演講主要圍繞 加強 KiCad 中的自定義
HarmonyOS實戰:高德地圖自定義定位圖標展示
的問題,建議點贊收藏! 實現效果 需求分析 首先需要實現一個自定義的圖標替代系統默認的箭頭。 獲取定位權限與位置信息。 獲取定位結果并展示當前位置。 技術實現 在鴻蒙的實際開發過程中,地圖定位權限首先需要申請兩個權限,
HarmonyOS應用自定義鍵盤解決方案
自定義鍵盤是一種替換系統默認鍵盤的解決方案,可實現鍵盤個性化交互。允許用戶結合業務需求與操作習慣,對按鍵布局進行可視化重構、設置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護層面,自定義鍵盤可以
如何添加自定義單板
在開發過程中,用戶有時需要創建自定義板配置。本節將通過一個實例講解用戶如何創建屬于自己的machine,下面以g2l-test.conf為例進行說明。
HarmonyOS實戰:自定義時間選擇器
評論