精品欧美一区二区三区在线观看 _久久久久国色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久久久久国产一区二区| 国产麻豆剧传媒精品国产av| 日本高清视频在线观看| 国产一区二区成人久久免费影院| 久久久久国色av免费观看性色 | 免费三级在线观看| 91麻豆精品国产91久久久久推荐资源| 午夜欧美2019年伦理| 日韩av一区二区三区美女毛片| 91精品中文字幕| 亚洲久久成人| 日韩在线视频一区| 中文字幕人妻一区二区三区| 成人在线观看免费播放| 亚洲第一在线综合网站| 亚洲高清123| 神马一区二区三区| 国内成+人亚洲+欧美+综合在线 | 久久婷婷国产综合精品青草| 国产美女久久精品香蕉69| 久久久久久久九九九九| 成人精品视频| 日韩精品视频免费在线观看| 天天爽夜夜爽视频| 欧美黄色三级| 天天综合网天天综合色| 国产人妻互换一区二区| 国产剧情在线观看| 99在线热播精品免费| 91在线网站视频| 中文字幕日韩三级| 久久aⅴ国产紧身牛仔裤| 色综合久久悠悠| 大吊一区二区三区| 国产精品一国产精品| 亚洲国产91色在线| 亚洲少妇一区二区三区| 精品三级国产| 在线成人av网站| 国产一二三区av| 欧美福利在线播放| 欧美性xxxx极品hd满灌| 少妇高潮喷水在线观看| 黄网在线免费看| 亚洲主播在线观看| 艳母动漫在线观看| 麻豆视频在线观看免费网站| 国产欧美精品一区二区三区四区 | 色婷婷在线视频| 国产mv日韩mv欧美| 91视频免费进入| av在线资源观看| 国产一区二区三区视频在线播放| 国产女精品视频网站免费| 一区精品在线观看| 激情图区综合网| 91天堂在线观看| 99在线精品视频免费观看20| 寂寞少妇一区二区三区| 成人日韩在线电影| 99国产在线播放| 国产成人午夜精品5599 | 免费日韩中文字幕| 网友自拍亚洲| 欧美三级午夜理伦三级中视频| 午夜视频在线瓜伦| 国产精品蜜月aⅴ在线| 欧美精品vⅰdeose4hd| 亚洲欧美aaa| 精品一区视频| 亚洲国产精品中文| 97超碰在线资源| 日本a口亚洲| 久久久久99精品久久久久| 青青草原在线免费观看| 在线国产日韩| 国产精品对白刺激| 国产又大又黄又爽| 不卡电影免费在线播放一区| 精品在线视频一区二区| 国产理论电影在线观看| 亚洲人成亚洲人成在线观看图片| 国产三级中文字幕| xxxx另类黑人| 欧美性受xxxx黑人xyx性爽| 亚洲欧美自偷自拍另类| 在线视频亚洲欧美中文| 国产丝袜一区二区三区| 久久免费手机视频| 亚洲夜间福利| 国产精品手机播放| 好男人在线视频www| 久久精品在这里| gogogo免费高清日本写真| 欧美激情成人动漫| 在线观看日韩电影| 黑森林av导航| 欧美色爱综合| 国语自产精品视频在线看抢先版图片 | 色777狠狠狠综合伊人| 欧美成人四级hd版| 亚洲综合久久网| 狠狠色综合色综合网络| 国产日韩一区二区三区| fc2在线中文字幕| 亚洲一区二区三区四区在线免费观看 | 九七久久人人| 欧美性xxxxxxxxx| 亚洲区 欧美区| 欧美日韩性在线观看| 欧美激情综合亚洲一二区| 黄色污污视频软件| av在线不卡观看免费观看| 亚洲一区二区三区免费观看| 日韩伦理在线一区| 91精品国产91久久久久久一区二区 | 国内自拍中文字幕| 欧美日韩免费电影| 亚洲欧洲国产精品| jizz国产免费| 国产老肥熟一区二区三区| 日韩精品久久一区二区三区| 国产第一页在线| 欧美精品乱码久久久久久按摩| 性久久久久久久久久| 伊人久久亚洲美女图片| 亚洲精品免费在线视频| 在线观看免费网站黄| 黑人巨大精品欧美一区免费视频| 日本少妇一级片| 国产精品久久久久久影院8一贰佰 国产精品久久久久久麻豆一区软件 | 情事1991在线| 天天干天天干天天干| 亚洲摸摸操操av| 欧美美女性视频| 成人三级视频| 国产精品久久久久久搜索| 欧美老女人性开放| 日韩欧美成人精品| 国产精品久久久免费观看| 午夜日韩av| 91免费观看| 性欧美ⅴideo另类hd| 欧美日韩成人高清| 国产成人精品视频免费| 青娱乐精品在线视频| 日韩高清dvd| 国产精品亚洲d| 自拍偷拍亚洲欧美| 亚洲熟妇av乱码在线观看| 欧美国产日韩在线观看| 91国产精品视频在线观看| 欧美日韩高清| 91精品国产综合久久香蕉最新版 | 一区二区三区欧美视频| aaaaaaaa毛片| 国产精品va| 国产一区二区三区四区hd| 高端美女服务在线视频播放| 日韩精品视频在线| 啪啪小视频网站| 国产精品白丝在线| 日韩av影视大全| 国内久久精品| 久热国产精品视频一区二区三区| 韩国成人动漫| 欧美日韩亚洲国产精品| 97视频com| 深夜福利在线视频| 欧美特黄视频| 99久久99久久| 免费高潮视频95在线观看网站| 日韩精品视频观看| 艳妇乳肉豪妇荡乳av| 亚洲美女屁股眼交3| 男女性杂交内射妇女bbwxz| 国产视频一区三区| 先锋在线资源一区二区三区| 国产精品免费精品自在线观看| 色综合久久久久久中文网| 深夜福利免费在线观看| 欧美调教femdomvk| 九九热视频精品| 三级成人在线视频| 亚洲一区精品视频| 高清欧美性猛交xxxx黑人猛| 青青久久aⅴ北条麻妃| 免费不卡视频| 亚洲国产成人精品一区二区| 国产天堂第一区| 一区二区三区在线播放| 一区二区三区免费在线观看视频| 免费观看一级特黄欧美大片| 免费的一级黄色片| 九九亚洲视频| 成人女人免费毛片| 成人午夜一级| 97高清免费视频| 午夜在线小视频| 亚洲国产精品成人av| 97国产精品久久久| 欧美性极品少妇精品网站| 日韩一卡二卡在线观看| 97aⅴ精品视频一二三区| 99re6在线观看| 久久久亚洲一区| 特级西西444| 精品一级毛片| 国产综合av一区二区三区| 四虎精品在线观看| 日韩av免费一区| 久久香蕉一区| 草民午夜欧美限制a级福利片| 免费一级毛片在线观看| 日韩女优电影在线观看| 一区二区不卡视频在线观看| 懂色av影视一区二区三区| 欧美成人免费观看视频| 国产精品久线在线观看| 久久久久久久久久久国产精品| 国产激情一区二区三区四区| 天天综合网日韩| 久久精品五月| 成人一对一视频| 狠狠入ady亚洲精品| 永久免费精品视频网站| 精品视频免费在线观看| 成人动漫视频在线观看免费| 亚洲美女色播| 国产日韩欧美视频| 日本h片久久| 国产精品极品在线| 欧美成人黑人| 日本欧美爱爱爱| 在线女人免费视频| 91成人在线视频| 女海盗2成人h版中文字幕| 久久久亚洲天堂| 91九色国产在线播放| 国模gogo一区二区大胆私拍| 黄页网站在线| 高清一区二区三区四区五区| 欧洲一区二区三区| 久久久久久久久久婷婷| 国产偷倩在线播放| 97激碰免费视频| 精品众筹模特私拍视频| 欧美成人精品h版在线观看| 黄色av网站在线播放| 日韩一区视频在线| 国产a级免费视频| 在线91免费看| 精品国产区一区二| 精品剧情v国产在线观看在线| 亚洲AV无码精品国产| 精品国产三级电影在线观看| 蜜臀av午夜精品| 日韩黄色高清视频| 欧美女优在线| 日韩视频免费在线观看| 黄色精品免费看| 欧美高清在线视频观看不卡| 多野结衣av一区| 国产成人精品久久二区二区| 日韩一区精品| 91在线观看免费| 国产精品videossex| 另类小说综合网| 日韩一区二区在线免费| av中文字幕av| 一区二区精品| 91小视频网站| 国产丶欧美丶日本不卡视频| 好男人香蕉影院| 欧美激情一区二区在线| 亚洲一级生活片| 精品久久久国产| 中文字幕第31页| 国产精品综合二区| 亚洲精品视频一二三| 综合激情在线| 国产a级一级片| 捆绑调教一区二区三区| 国产伦理在线观看| 久久亚洲综合色一区二区三区| 免费成人深夜天涯网站| 成人视屏免费看| 人妻精品久久久久中文字幕| 中文字幕av一区二区三区| 外国一级黄色片| 色偷偷一区二区三区| 国产美女裸体无遮挡免费视频| 亚洲第一精品夜夜躁人人躁| 国产福利第一视频在线播放| 欧美精品一二区| 欧美三级精品| 成人欧美一区二区三区黑人免费| 国产成人三级| 成人短视频在线观看免费| 久久婷婷丁香| youjizz.com日本| 中文字幕中文在线不卡住| 亚洲精品视频在线观看免费视频| 欧美日韩视频在线观看一区二区三区| www.污视频| 色偷偷88888欧美精品久久久| 成人免费观看在线观看| 成人精品视频在线| 欧美色婷婷久久99精品红桃| 精品人妻人人做人人爽| 日本麻豆一区二区三区视频| 成人做爰www看视频软件| 国产精品高潮呻吟| 无码人妻精品一区二| 精品国产免费久久| jizz性欧美| 国产精品欧美激情| 亚洲人成网亚洲欧洲无码| 蜜桃视频一区二区在线观看| 青青草精品视频| 精品人妻无码一区二区三区换脸| 亚洲一区二区三区四区在线免费观看| 国产影视一区二区| 在线播放亚洲激情| 欧美日韩美女| 久久综合九色综合久99| 一区免费视频| 色诱av手机版| 亚洲综合免费观看高清完整版| 一区二区的视频| 日韩有码在线电影| 欧美与亚洲与日本直播| 欧洲一区二区在线| 亚洲在线一区| 国产肉体xxxx裸体784大胆| 亚洲国产乱码最新视频| а√中文在线资源库| 久久成人免费视频| а天堂中文最新一区二区三区| 亚洲一区二三| 精彩视频一区二区| 国产一区二区视频在线观看免费| 欧美人xxxx| 日本在线免费| 91久久精品国产91性色| 亚洲成人精品| 中文字幕第10页| 亚洲一二三四区| 成人午夜视频一区二区播放| 欧美丰满少妇xxxx| 嗯用力啊快一点好舒服小柔久久| 日韩a级在线观看| 99热在这里有精品免费| 天堂网av手机版| 亚洲欧美日韩另类| 97成人超碰| 亚洲国产精品一区二区第一页| 日韩成人免费电影| 欧美性生交大片| 欧美一区二区三级| 国产桃色电影在线播放| 久久久精品动漫| 日韩电影在线一区| 美国一级片在线观看| 欧美成人精品高清在线播放| 波多野结衣中文字幕久久| 国产呦系列欧美呦日韩呦| 一区免费视频| 娇妻被老王脔到高潮失禁视频| 欧美日韩一级二级三级| 国产福利在线播放麻豆| 国产偷久久久精品专区| 日本中文一区二区三区| 色欲一区二区三区精品a片| 日韩精品一区二区三区视频播放 | 国产一区视频免费观看| 国产精品毛片a∨一区二区三区| 国产精品热久久| 韩国三级电影久久久久久| 神马影视一区二区| 亚洲欧美天堂在线| 性欧美疯狂xxxxbbbb| 欧美伦理影视网| 91探花福利精品国产自产在线 | 午夜精品www| 欧美亚洲国产激情| 亚洲精品乱码久久久久久动漫| 亚洲午夜精品久久久久久久久| 九色在线免费| 不卡的av一区| 日韩精品免费专区| 国产盗摄一区二区三区在线| 亚洲国产欧美自拍| 欧美天堂在线| 日韩在线一级片| 亚洲另类春色国产| av福利在线播放| 久久免费看av| 国产福利精品一区二区| 中文字幕 国产精品|