午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

vue實現簡易計時器組件

瀏覽:30日期:2023-02-17 10:43:08

在做項目中難免會碰到需要實時刷新,廣告動畫依次出現等等需求,剛最近基于業務需求,需要實現一個累加通話時長的計時器,這時候就需要定時器登上我們的代碼舞臺了,其實對于計時器,它的原理就是通過定時器來實現的,那么在寫業務需求之前,我先說說關于定時器的一些知識。

window對象提供了兩個方法來實現定時器的效果,分別是window.setTimeout()和window.setInterval。

在Javascript中,代碼一般都是同步執行的,但定時器卻是異步執行的。

window.setTimeout(callback,delay); //callback:回調函數 delay:時間間隔時長window.setInterval(callback,delay);

定時器分為隔時定時器setInterval和延時定時器setTimeout

那么它們兩到底有什么區別呢?

setInterval以指定時間為周期循環執行,一般用于刷新表單、復雜動畫的循環執行,對于一些表單的實時指定時間刷新同步 setTimeout只在指定時間后執行一次,像有些網站剛進去會出現一個彈窗廣告,一般都是用的setTimeout

了解了定時器的基本知識之后,那么接下來就可以進行功能的實現了。

HTML

<template> <div class='timer'> <div>{{nowTime}}</div> </div></template>

Javascript

<script> export default { name: ’Timer’, data () { return { timer: null, nowTime:'', hour: 0, minutes: 0, seconds: 0 } }, created () { this.timer = setInterval(this.startTimer, 1000); }, destroyed () { clearInterval(this.timer); },methods: { startTimer () { //建議開啟定時器前,先清除定時器,避免定時器累加,出現不可預期的bug if(this.timer) { clearInterval(this.timer); } this.seconds += 1; if (this.seconds >= 60) { this.seconds = 0; this.minutes= this.minutes+ 1; } if (this.minutes>= 60) { this.minutes= 0; this.hour = this.hour + 1; } this.nowTime = this.toZero(this.hour): this.toZero(this.minutes):this.toZero(this.seconds) }, toZero(timeNumber) { return timeNumber<10?'0'+timeNumber:timeNumber }, }}</script>

這樣,一個簡單的計時器組件就實現好了,其實還有其他的實現思路,如果以后開發碰到了類似的需求,可以借鑒,希望對你們有所幫助。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 国产精品网页 | 成人av在线一区二区 | 色桃花网 | 欧美 日韩 精品 | 亚洲色图日韩 | 久久xxx| 一区二区欧美日韩 | 成人免费视频网 | 亚洲国产精品一 | 日本韩国欧美一区 | 成人一二三四区 | 特黄特色大片免费播放器使用方法 | www.自拍偷拍| 久久久999国产精品 日韩av手机在线免费观看 | 99国产精品久久久久久久成人 | 亚洲成人国产精品 | 亚洲 精品 综合 精品 自拍 | 欧美成人精品一区二区三区在线看 | 成人在线91 | 国产成人精品免费视频 | 91一区二区三区在线观看 | 黄色a大片 | 国产资源av | 91精品视频免费在线观看 | 十八女人毛片 | 欧美一级做a爰片免费视频 天堂久久精品 | 亚洲一区在线播放 | 欧美特级黄色大片 | 91网站免费观看 | 中文字幕在线免费看 | 国产综合网站 | 日韩不卡一区二区 | 久久久久国产 | wwwxx国产| 村上里沙av | 99成人免费视频 | 综合狠狠 | 国产精品日韩一区二区 | 伊人超碰| 艳母动漫在线免费观看 | 日韩免费视频一区二区视频在线观看 |