<template>
<div class="timer">
<p>{{ formatTime }}</p>
<button @click="startTimer" v-if="!isTiming">开始计时</button>
<button @click="stopTimer" v-else>停止计时</button>
</div>
</template>
<script>
export default {
data() {
return {
isTiming: false,
time: 0,
timer: null
}
},
computed: {
formatTime() {
const minutes = Math.floor(this.time / 60)
const seconds = this.time % 60
return `${minutes}:${seconds < 10 ? '0' : ''}${seconds}`
}
},
methods: {
startTimer() {
this.isTiming = true
this.timer = setInterval(() => {
this.time++
}, 1000)
},
stopTimer() {
this.isTiming = false
clearInterval(this.timer)
}
}
}
</script>
<style>
.timer {
text-align: center;
font-size: 24px;
margin-top: 50px;
}
</style>
在Uni-app中实现计时器效果
蜕变菜鸟2024-08-27 17:46
相关推荐
用户8127482815120几秒前
安卓java端service如何在native进程进行访问-跨进程通讯高端知识Shirley~~几秒前
Web Audio APITEC_INO1 分钟前
STM32_11:DMA鹏北海1 分钟前
qiankun微前端通信与路由方案总结韩曙亮2 分钟前
【Web APIs】浏览器本地存储 ② ( window.sessionStorage 本地存储常用 API 简介 | 代码示例 )time_rg4 分钟前
深入理解react——2. Concurrent Mode0_14 分钟前
封装了一个vue版本 Pag组件Stirner7 分钟前
A2UI : 以动态 UI 代替 LLM 文本输出的方案Code知行合壹9 分钟前
Vue.js进阶我叫唧唧波14 分钟前
【微前端】qiankun基础