99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

HarmonyOS實戰(zhàn):自定義時間選擇器

尤楓 ? 來源:jf_54996641 ? 作者:jf_54996641 ? 2025-06-09 15:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

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

實現(xiàn)效果

需求分析

  1. 默認選中日期為當前時間。
  2. 支持精確到時分。
  3. 注意閏年的計算。

技術(shù)實現(xiàn)

  1. 首先要想實現(xiàn)時間選擇器,需要使用一個上下可以滾動的控件,這里使用鴻蒙官方提供的 TextPicker,TextPicker 控件支持內(nèi)容的上下滾動,可以用來顯示年月日的選擇器,確定了控件后,先計算日期。
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 年為周期。

  1. 根據(jù)計算得到的日期數(shù)據(jù)集合,使用 TextPicker 顯示年月日,同時默認選中當前時間 choseDay。
TextPicker({ range: this.timeList, value: this.choseDay })
            .pickerStyle()
            .onChange((value, index) = > {
              this.choseDay = value.toString()
            })
            .width(105)
  1. 計算時分數(shù)據(jù)。
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?"時":""))
    }
  1. 分別使用 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)
        })
  1. 要讓時間選擇器默認選擇當前時間時,需要注意選擇器的格式為"2012-01-01",需要在計算時不足 10 時補 0。否則時間選擇器不會默認選中當前時間。
  2. 鴻蒙官方的 Date 類默認提供的月份是從 0 開始的,也就是說通過 data.getUTCMoth()獲取的月份默認范圍為 [0,11],而選擇器需要顯示的是 [1,12],這里需要手動處理。

總結(jié)

自定義時間選擇器看似簡單,其實需要注意的地方不少,時間的計算,時間的顯示格式,默認選中當前時間等。都需要開發(fā)者在日常開發(fā)中注意計算細節(jié)??吹竭@里相信你已經(jīng)學(xué)會了怎么自定義一個時間選擇器了,快去動手試試吧!

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2126

    瀏覽量

    33079
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    大彩講堂:VisualTFT軟件如何自定義圓形進度條

    VisualTFT軟件如何自定義圓形進度條
    的頭像 發(fā)表于 07-07 17:10 ?509次閱讀
    大彩講堂:VisualTFT軟件如何<b class='flag-5'>自定義</b>圓形進度條

    HarmonyOS實戰(zhàn):3秒實現(xiàn)一個自定義輪播圖

    那么簡單,需要考慮的細節(jié)很多。不過在 HarmonyOS 中實現(xiàn)一個輪播圖卻是十分的簡單,本篇文章教你在最短的時間內(nèi)快速實現(xiàn)一個自定義的 輪播圖,建議點贊收藏!
    的頭像 發(fā)表于 06-24 17:06 ?145次閱讀

    KiCad 中的自定義規(guī)則(KiCon 演講)

    “ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規(guī)則系統(tǒng),并詳細講解了自定義規(guī)則的設(shè)計與實例。? ” ? 演講主要圍繞 加強 KiCad 中的自定義
    的頭像 發(fā)表于 06-16 11:17 ?611次閱讀
    KiCad 中的<b class='flag-5'>自定義</b>規(guī)則(KiCon 演講)

    HarmonyOS實戰(zhàn):高德地圖自定義定位圖標展示

    的問題,建議點贊收藏! 實現(xiàn)效果 需求分析 首先需要實現(xiàn)一個自定義的圖標替代系統(tǒng)默認的箭頭。 獲取定位權(quán)限與位置信息。 獲取定位結(jié)果并展示當前位置。 技術(shù)實現(xiàn) 在鴻蒙的實際開發(fā)過程中,地圖定位權(quán)限首先需要申請兩個權(quán)限,
    的頭像 發(fā)表于 06-09 14:59 ?237次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>實戰(zhàn)</b>:高德地圖<b class='flag-5'>自定義</b>定位圖標展示

    HarmonyOS應(yīng)用自定義鍵盤解決方案

    自定義鍵盤是一種替換系統(tǒng)默認鍵盤的解決方案,可實現(xiàn)鍵盤個性化交互。允許用戶結(jié)合業(yè)務(wù)需求與操作習慣,對按鍵布局進行可視化重構(gòu)、設(shè)置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護層面,自定義鍵盤可以
    的頭像 發(fā)表于 06-05 14:19 ?690次閱讀

    LabVIEW運動控制(三):EtherCAT運動控制的高效加工指令自定義封裝

    LabVIEW高效加工指令自定義封裝
    的頭像 發(fā)表于 04-08 13:49 ?2696次閱讀
    LabVIEW運動控制(三):EtherCAT運動控制<b class='flag-5'>器</b>的高效加工指令<b class='flag-5'>自定義</b>封裝

    如何添加自定義單板

    在開發(fā)過程中,用戶有時需要創(chuàng)建自定義板配置。本節(jié)將通過一個實例講解用戶如何創(chuàng)建屬于自己的machine,下面以g2l-test.conf為例進行說明。
    的頭像 發(fā)表于 03-12 14:43 ?590次閱讀

    如何快速創(chuàng)建用戶自定義Board和App工程

    概述自HPM_SDKv1.7.0發(fā)布開始,在HPM_ENV中新增了user_template文件夾,以方便用戶快速創(chuàng)建自定義的Board和App工程。user_template是用戶模板工程,用戶
    的頭像 發(fā)表于 02-08 13:38 ?524次閱讀
    如何快速創(chuàng)建用戶<b class='flag-5'>自定義</b>Board和App工程

    Altium Designer 15.0自定義元件設(shè)計

    電子發(fā)燒友網(wǎng)站提供《Altium Designer 15.0自定義元件設(shè)計.pdf》資料免費下載
    發(fā)表于 01-21 15:04 ?0次下載
    Altium Designer 15.0<b class='flag-5'>自定義</b>元件設(shè)計

    think-cell:自定義think-cell(四)

    C.5 設(shè)置默認議程幻燈片布局 think-cell 議程可以在演示文稿中使用特定的自定義布局來定義議程、位置和議程幻燈片上的其他形狀,例如標題或圖片。通過將此自定義布局添加到模板,您可以為整個組織
    的頭像 發(fā)表于 01-13 10:37 ?512次閱讀
    think-cell:<b class='flag-5'>自定義</b>think-cell(四)

    think-cell;自定義think-cell(一)

    本章介紹如何自定義 think-cell,即如何更改默認顏色和其他默認屬性;這是通過 think-cell 的樣式文件完成的,這些文件將在前四個部分中進行討論。 第五部分 C.5 設(shè)置默認議程幻燈片
    的頭像 發(fā)表于 01-08 11:31 ?744次閱讀
    think-cell;<b class='flag-5'>自定義</b>think-cell(一)

    創(chuàng)建自定義的基于閃存的引導(dǎo)加載程序(BSL)

    電子發(fā)燒友網(wǎng)站提供《創(chuàng)建自定義的基于閃存的引導(dǎo)加載程序(BSL).pdf》資料免費下載
    發(fā)表于 09-19 10:50 ?0次下載
    創(chuàng)建<b class='flag-5'>自定義</b>的基于閃存的引導(dǎo)加載程序(BSL)

    如何自定義內(nèi)存控制的設(shè)置

    在FreeRTOS中自定義內(nèi)存控制的設(shè)置,主要涉及到內(nèi)存分配策略的選擇和配置。FreeRTOS提供了多種內(nèi)存分配策略,如heap_1、heap_2、heap_3、heap_4和heap_5,每種
    的頭像 發(fā)表于 09-02 14:28 ?935次閱讀

    EtherCAT運動控制PT/PVT實現(xiàn)用戶自定義軌跡規(guī)劃

    EtherCAT運動控制PT/PVT實現(xiàn)用戶自定義軌跡規(guī)劃。
    的頭像 發(fā)表于 08-15 11:49 ?1258次閱讀
    EtherCAT運動控制<b class='flag-5'>器</b>PT/PVT實現(xiàn)用戶<b class='flag-5'>自定義</b>軌跡規(guī)劃

    NVIDIA NeMo加速并簡化自定義模型開發(fā)

    如果企業(yè)希望充分發(fā)揮出 AI 的力量,就需要根據(jù)其行業(yè)需求量身定制的自定義模型。
    的頭像 發(fā)表于 07-26 11:17 ?1260次閱讀
    NVIDIA NeMo加速并簡化<b class='flag-5'>自定義</b>模型開發(fā)