精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

HarmonyOS - 自定義組件之計時器

系統 OpenHarmony
前段時間項目中遇到了計時器的功能,項目中的計時器其實只是顯示功能,數據全是由設備上報的。完成項目后,自己做了一個小的計時器組件,在這個過程中也發現了一些問題。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

前言

前段時間項目中遇到了計時器的功能,項目中的計時器其實只是顯示功能,數據全是由設備上報的。完成項目后,自己做了一個小的計時器組件,在這個過程中也發現了一些問題。

效果展示

組件直接傳入以秒為單位的數據,最終顯示如下效果:

#夏日挑戰賽# HarmonyOS - 自定義組件之計時器-開源基礎軟件社區

實現原理

1、用setTimeout模擬setInterval的行為

正常情況下,說到計時器首先想到的是使用setInterval,對比setTimeout要去重復調用,setInterval很方便就能實現,如下代碼:

getTime(time) {
this.countNum = time;
setTimeout(() => {
this.getTime(time --)
}, 1000)
},
setInterval(() => {
this.countNum --
}, 1000)

但為什么要使用setTimeout呢,查下兩個定時器的原理,會發現,創建一個時間間隔為100ms的定時器,setInterval每隔100ms往隊列中添加一個事件;100ms后,添加T1定時器代碼至隊列中,主線程中還有任務在執行,所以等待,some event執行結束后執行T1定時器代碼;又過了100ms,T2定時器被添加到隊列中,主線程還在執行T1代碼,所以等待;又過了100ms,理論上又要往隊列里推一個定時器代碼,但由于此時T2還在隊列中,所以T3不會被添加,結果就是此時被跳過;這里我們可以看到,T1定時器執行結束后馬上執行了T2代碼,所以并沒有達到定時器的效果。

#夏日挑戰賽# HarmonyOS - 自定義組件之計時器-開源基礎軟件社區

綜上所述,setInterval有兩個缺點:

  1. 使用setInterval時,某些間隔會被跳過。
  2. 可能多個定時器會連續執行。

所以,我們要使用setTimeout模擬setInterval,來規避掉上面的缺點。

2、用Date.now()獲取當前時間,規避瀏覽器退出再進來造成的計時誤差

當我們在使用計時工具的時候,因為一些原因,將瀏覽器退到后臺,再次進來的時候,發現計時器時間不對,感覺剛才退出去的這段時間,計時器是停止狀態。針對這個問題,查詢會發現,出于節能的考慮, 部分瀏覽器在進入后臺時(或者失去焦點時), 會將 setTimeout 等定時任務暫停,待用戶回到瀏覽器時, 才會重新激活定時任務。

說是暫停,實踐操作會發現其實應該說是延遲, 1s 的任務延遲到 2s, 或者更久,總之,計時器計算掉的時間,比實際過去的時間少。解決這個問題,我們可以使用Date.now()記錄時間,如下,計算兩次計時事件的時間差,來計算每次計時的step。

getTime(time) {
this.countNum = time;
setTimeout(() => {
const nowDate = Date.now()
const diff = Math.floor((nowDate - this.curTime) / 1000)
const step = diff > 1 ? diff : 1 // 頁面退到后臺后計時有偏差,對比時間差,得到計時step
this.curTime = nowDate
this.getTime(time - step)
}, 1000)
},

3、及時清理定時器

這是容易忽略的一點,我們的組件唯一的一個prop屬性就是time,實際的業務場景中,可能會有一些操作改變倒計時的時長,所以我們的組件需要監聽time值的改變,來做一些初始化操作,這時候你會發現,當做了2次初始化操作后,我們的代碼中會同時存在了2個計時器,時間過了1秒后2個計時器同時觸發,對time值做了2次“- 1”操作,所以,我們在初始化時要清除之前的定時器。

getTime(time) {
this.timer && clearTimeout(this.timer) //清除定時器
this.countNum = time;
this.timer = setTimeout(() => {
const nowDate = Date.now()
const diff = Math.floor((nowDate - this.curTime) / 1000)
const step = diff > 1 ? diff : 1 // 頁面退到后臺后計時有偏差,對比時間差,得到計時step
this.curTime = nowDate
this.getTime(time - step)
}, 1000)
},

實現過程

countDown組件hml部分:

<div class="count-down">
<image class="count" src="./count.png"></image>
<div class="countNumCon">
<text class="countNum">
{{countNum}}
</text>
</div>
</div>

countDown組件js部分:

export default {
props: [
'time'
],
data: {
timer: null, //定時器
curTime: 0, //記錄上次操作時間
countNum: '',
},
onInit() {
this.countDown()
this.$watch('time', 'countDown');
},
//將傳入的時間(s)轉換成天/小時/分鐘/秒
durationFormatter(time) {
if (!time) return { ss: 0 }
let t = time
const ss = t % 60
t = (t - ss) / 60
if (t < 1) return { ss }
const mm = t % 60
t = (t - mm) / 60
if (t < 1) return { mm, ss }
const hh = t % 24
t = (t - hh) / 24
if (t < 1) return { hh, mm, ss }
const dd = t
return { dd, hh, mm, ss }
},
//處理時間格式
dealTime(time){
return `00${time || ''}`.slice(-2);
},
countDown() {
this.curTime = Date.now()
this.getTime(this.time)
},
//計算時間
getTime(time) {
this.timer && clearTimeout(this.timer)
if (time < 0) {
return
}
const { dd, hh, mm, ss } = this.durationFormatter(time)
this.countNum = `${dd || 0}天 ${this.dealTime(hh)}:${this.dealTime(mm)}:${this.dealTime(ss)}`;
this.timer = setTimeout(() => {
const nowDate = Date.now()
const diff = Math.floor((nowDate - this.curTime) / 1000)
const step = diff > 1 ? diff : 1 // 頁面退到后臺的時候不會計時,對比時間差,大于1s的重置倒計時
this.curTime = nowDate
this.getTime(time - step)
}, 1000)
},
};

countDown組件css部分:

.count-down {
display: flex;
margin-top: 200px;
justify-content: center;
align-items: center;
flex-direction: column;
width: 100%;
height: 50%;
}
.countImg {
width: 200px;
height: 100px;
}
.numContainer {
background-color: black;
height: 57px;
width: 140px;
left: 8px;
top: -80px;
justify-content: center;
border-radius: 7px;
}
.count {
color: white;
font-size: 22px;
font-weight: 500;
}

父組件hml部分:

<element name="countDown" src="../countDown/countDown.hml">
</element>
<div class="container">
<countDown time="{{ leftTime }}">
</countDown>
</div>

父組件js部分:

export default {
data: {
leftTime: 100,
},
};

總結

這個計時器組件就是對日常工作的發散,作為一個鴻蒙小白,順便做一個小小的練習。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??。

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2022-07-06 20:24:08

ArkUI計時組件

2022-04-24 15:17:56

鴻蒙操作系統

2022-07-12 16:56:48

自定義組件鴻蒙

2021-11-01 10:21:36

鴻蒙HarmonyOS應用

2023-02-20 15:20:43

啟動頁組件鴻蒙

2022-06-30 14:02:07

鴻蒙開發消息彈窗組件

2021-09-15 10:19:15

鴻蒙HarmonyOS應用

2022-07-15 16:45:35

slider滑塊組件鴻蒙

2022-10-26 15:54:46

canvas組件鴻蒙

2022-10-25 15:12:24

自定義組件鴻蒙

2012-05-08 13:58:37

SharePoint

2011-05-31 16:50:35

Android 線程

2021-11-22 10:00:33

鴻蒙HarmonyOS應用

2021-12-21 15:22:22

鴻蒙HarmonyOS應用

2022-06-20 15:43:45

switch開關鴻蒙

2022-02-21 15:16:30

HarmonyOS鴻蒙操作系統

2021-12-24 15:46:23

鴻蒙HarmonyOS應用

2022-02-16 16:09:12

鴻蒙游戲操作系統

2022-02-16 15:25:31

JS代碼Canvas鴻蒙

2009-06-24 15:13:36

自定義JSF組件
點贊
收藏

51CTO技術棧公眾號

韩国福利在线| 影音先锋亚洲天堂| 久久久精品区| 亚洲国产精品自拍| 茄子视频成人在线观看 | 成人午夜两性视频| 久久视频免费看| 女优一区二区三区| 91精品婷婷国产综合久久性色| 国产一二三区在线播放| 精品推荐蜜桃传媒| 国产精品亚洲第一区在线暖暖韩国| 久久久亚洲国产| 国产欧美小视频| 成人午夜大片| 欧美日韩一卡二卡三卡 | 136福利第一导航国产在线| 久久免费偷拍视频| 亚洲综合最新在线| 无码免费一区二区三区| 欧美精品国产一区| 尤物精品国产第一福利三区| ass极品水嫩小美女ass| 国产一区二区三区影视| 午夜电影一区二区三区| 午夜啪啪免费视频| 国产一级网站视频在线| 成人国产在线观看| 成人免费网站在线| 精品乱码一区内射人妻无码| 亚洲一级一区| 操91在线视频| 国产馆在线观看| 小嫩嫩12欧美| 亚洲国产精品资源| 国产xxx在线观看| 四虎影视精品永久在线观看| 日本精品一级二级| 北条麻妃在线视频观看| 青草在线视频在线观看| 亚洲天堂a在线| 亚洲韩国在线| 北条麻妃在线| 久久精品欧美一区二区三区不卡| 久久精品国产精品国产精品污| 国产99视频在线| 精品在线免费视频| 国产精品自产拍在线观| 日韩精选在线观看| 日韩精品一级二级 | 福利一区在线| 91高清视频在线| 亚洲中文字幕久久精品无码喷水| 色是在线视频| 欧美性xxxxx极品娇小| 一二三四视频社区在线| 1区2区3区在线| 精品成人久久av| 18禁免费观看网站| 性xxxxfreexxxxx欧美丶| 高跟丝袜欧美一区| 欧美三级一级片| 综合毛片免费视频| 在线视频中文字幕一区二区| 日本熟妇人妻中出| 欧美三级电影网址| 欧美一区二区三区在线观看 | 国产麻豆精品| 精品日韩在线一区| 国产在线观看无码免费视频| 特黄特色欧美大片| 亚洲欧美制服中文字幕| 三年中国中文观看免费播放| 欧美超碰在线| 欧美丰满片xxx777| 91精品国产乱码在线观看| 免费看的黄色欧美网站| 国产精品视频久久久| 在线观看一二三区| 国产精品综合一区二区| 精品在线视频一区二区三区| 国产成人天天5g影院在线观看| 国产精品全国免费观看高清| 一本色道久久88亚洲精品综合| 国产深夜视频在线观看| 色天使色偷偷av一区二区| 日本不卡一区二区在线观看| 一区二区日韩| 亚洲欧洲日韩国产| 搜索黄色一级片| 一本色道久久| 成人xxxx视频| 婷婷丁香花五月天| 国产精品三级久久久久三级| 今天免费高清在线观看国语| 手机在线观看av网站| 欧美日韩亚洲综合在线| 欧美一区二区免费在线观看| 精品一区二区三| 欧美第一淫aaasss性| 精品人妻一区二区三区潮喷在线| 狠狠色伊人亚洲综合成人| 国产有色视频色综合| 亚洲成a人v欧美综合天堂麻豆| 一级女性全黄久久生活片免费| 日本成人在线免费视频| 午夜精品在线| 正在播放国产一区| 日本一级一片免费视频| 精品一区二区三区久久久| 精品国产免费一区二区三区 | 国产精品久久久久久久久久久久久久久久久久 | 久草免费资源站| 日韩片欧美片| 啪一啪鲁一鲁2019在线视频| 国产情侣一区二区| 国产亚洲1区2区3区| 国产欧美日韩小视频| 亚洲电影二区| 一区二区在线视频| 久久露脸国语精品国产91| 国产一区二区三区四区五区美女 | 国产精品久久无码| 午夜久久美女| 国产区精品在线观看| 免费在线性爱视频| 亚洲成人精品一区| 中文字幕第10页| 久久久久av| 国产精品久久久久久久久免费| 天天干天天草天天射| 一区二区三区中文字幕| 波多野结衣国产精品| 国产精品亚洲人成在99www| 午夜免费在线观看精品视频| jizz国产视频| 亚洲精品视频一区二区| 国内自拍第二页| 日韩啪啪电影网| 国产精品极品美女粉嫩高清在线| 四虎精品在线| 韩曰欧美视频免费观看| 久久久老熟女一区二区三区91| 激情丁香综合| 国产伦精品一区二区三区免费视频| 成人短视频在线| 欧美一区二区日韩一区二区| 午夜精品一区二区三级视频| 麻豆91在线播放免费| 亚洲精品一区二| 久久精品超碰| 久久久国产影院| av片免费播放| 亚洲一区在线观看免费| 韩国av中国字幕| 亚洲图片在线| 精品国产一区二区三区四区vr| 国产高清中文字幕在线| 亚洲国产精品中文| 亚洲精品中文字幕乱码三区91| 久久精品一区八戒影视| 青青在线视频免费| 91欧美在线| 91亚洲精品在线观看| 污网站在线免费看| 亚洲二区在线播放视频| 精品欧美一区二区三区免费观看| 久久一留热品黄| 不卡av免费在线| 国产精品成人av| 97国产超碰| 蜜桃视频动漫在线播放| 一个色综合导航| 国产乱色精品成人免费视频| 亚洲一区二区偷拍精品| 国产吞精囗交久久久| 日韩电影在线观看电影| 九九久久九九久久| 妖精视频一区二区三区免费观看| 国产精品国产三级国产专播精品人| jyzzz在线观看视频| 欧美一区二区大片| 中文字幕精品三级久久久| 中文字幕不卡三区| 国产亚洲精品成人a| 亚洲欧美网站| 99热这里只有精品7| 精品欧美午夜寂寞影院| 国产精品视频内| 日本不卡影院| 在线免费观看羞羞视频一区二区| 99热这里只有精| 色综合久久久久| 国产1区2区3区4区| 久久免费午夜影院| aaaaa黄色片| 日本大胆欧美人术艺术动态| 激情六月天婷婷| 欧美久久精品一级c片| 成人av中文| 国产成人福利夜色影视| 久久人人爽人人爽人人片av高请| 成av人电影在线观看| 精品成人一区二区三区| 97精品人妻一区二区三区香蕉| 天天综合色天天综合| 一级性生活免费视频| 久久综合九色综合97婷婷女人| 亚洲精品乱码久久久久久动漫| 麻豆成人精品| 777久久精品一区二区三区无码| 怕怕欧美视频免费大全| 国产精品日韩一区二区三区| 99视频有精品高清视频| 国产成人精品日本亚洲| 超黄网站在线观看| 欧美精品在线第一页| av亚洲在线| 亚洲欧美色图片| 日日夜夜精品免费| 欧美成人国产一区二区| 国产精品永久久久久久久久久| 一本一道波多野结衣一区二区| 久久免费黄色网址| 亚洲欧美视频在线观看| 激情无码人妻又粗又大| 国产性做久久久久久| 国产黄色网址在线观看| 成人国产电影网| 免费观看一区二区三区| 国产一区二区日韩精品| 久久久久久久久久一区| 青草国产精品久久久久久| 精品一区二区中文字幕| 国产一区二区三区成人欧美日韩在线观看 | 又紧又大又爽精品一区二区| 2017亚洲天堂| 国产精品无圣光一区二区| 中文字幕免费高清| 久久亚洲一区二区三区明星换脸 | 国产91视频在线| 欧美一级免费大片| 国产乱淫av片免费| 91精品黄色片免费大全| 97人人爽人人爽人人爽| 欧美群妇大交群的观看方式| 国产一区二区小视频| 欧美区一区二区三区| 亚洲在线精品视频| 欧美久久久久久蜜桃| 91片黄在线观看喷潮| 91麻豆精品91久久久久同性| 一级片视频网站| 欧美一区二区日韩| 亚洲国产精品suv| 亚洲成人精品在线| 午夜激情在线视频| 国产午夜精品一区理论片飘花| 国产在线一二| 日韩三级成人av网| 日韩专区av| 亚洲2020天天堂在线观看| 天堂中文av在线资源库| 日本视频久久久| 成人18视频在线观看| 国产日韩综合一区二区性色av| 99精品美女视频在线观看热舞| 亚洲精品免费一区二区三区| 色妞ww精品视频7777| 国产一区国产精品| 欧美日韩老妇| 九九久久九九久久| 亚洲一区中文| 一道本视频在线观看| 国产精品自拍三区| 污污内射在线观看一区二区少妇| 久久久www免费人成精品| 黄色激情小视频| 亚洲影院在线观看| 91精品国产综合久久久蜜臀九色| 欧美影视一区在线| 精品人妻一区二区三区麻豆91| 亚洲电影成人av99爱色| av在线电影院| 久久久久中文字幕| 欧洲av一区二区| 岛国视频一区免费观看| 国产欧美高清视频在线| av在线免费观看国产| 久久人人97超碰国产公开结果| www.污污视频| 99久久精品久久久久久清纯| 午夜视频一区二区在线观看| 亚洲系列中文字幕| 中文字幕资源网在线观看| 91国产美女视频| 日韩综合av| 久中文字幕一区| 91国语精品自产拍| 北条麻妃av高潮尖叫在线观看| 国内精品伊人久久久久影院对白| 中文字幕日韩三级片| 日韩美女久久久| 精品久久久久久久久久久国产字幕| 日韩一区二区在线免费观看| 国产一二三在线观看| 欧美激情在线视频二区| 欧美成人福利| 欧美久久综合性欧美| 亚洲视频观看| 色呦色呦色精品| 国产午夜亚洲精品午夜鲁丝片| 久久精品美女视频| 制服丝袜中文字幕一区| 国产小视频免费在线网址| 久久久久久久久久久久久久久久久久av | 1313精品午夜理伦电影| 亚洲日本精品| 美女网站久久| av免费观看不卡| 亚洲乱码中文字幕| 一级α片免费看刺激高潮视频| 日韩成人av在线播放| 白白色在线观看| 成人av资源网| 欧美色123| 日韩av福利在线观看| 亚洲欧洲日本在线| 亚洲一级视频在线观看| 亚洲性线免费观看视频成熟| 亚洲最大成人| 玛丽玛丽电影原版免费观看1977| 亚洲精华国产欧美| a级片在线观看视频| 亚洲男同1069视频| 国产99视频在线| 欧美成人激情视频免费观看| 成人污版视频| 欧美日韩一区二区三区电影| 精品一区二区三区久久久| 国产美女网站视频| 欧美男男青年gay1069videost| 337p日本欧洲亚洲大胆鲁鲁| 国产区精品在线观看| 欧美残忍xxxx极端| 999热精品视频| 亚洲精品大片www| 亚洲精品视频网| 国内自拍欧美激情| 日韩大胆成人| 成人在线观看黄| 亚洲国产岛国毛片在线| 中文字幕一二三四| 久久精品国亚洲| 精品午夜视频| 精品国产av无码一区二区三区| www.66久久| 国产超碰人人爽人人做人人爱| 亚洲免费小视频| 成人精品一区二区三区电影| 神马影院我不卡| 韩国三级中文字幕hd久久精品| 国产又色又爽又高潮免费| 91麻豆精品国产自产在线观看一区| 超鹏97在线| 狠狠色综合一区二区| 久久三级福利| 永久免费看mv网站入口| 欧美第一区第二区| 亚洲校园激情春色| 亚洲乱码一区二区三区| 国产一区二区三区免费| 日韩av电影网| 亚洲小视频在线| 国产一区二区三区免费在线| 日韩一级片免费视频| 久久精品免费在线观看| 国产免费黄色大片| 5252色成人免费视频| 日韩在线观看| 亚洲欧美日韩色| 欧洲精品在线观看| 在线观看午夜av| 欧美中日韩免费视频| 国产一区二区不卡在线 | 亚洲一区日韩在线| 99热6这里只有精品| 欧美精品一区男女天堂| 亚洲伦理影院| 妞干网视频在线观看| 国产欧美一区二区三区网站| 国产视频一区二区三区四区五区| 91精品国产乱码久久久久久久久 | av男人天堂一区| 中文字幕在线播出| 91av视频在线免费观看| 婷婷丁香综合| 国产精品密蕾丝袜| 欧美成人aa大片| 亚洲国产aⅴ精品一区二区三区|