<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
相关推荐
祝余呀10 分钟前
HTML初学者第四天浮桥1 小时前
vue3实现pdf文件预览 - vue-pdf-embed七夜zippoe2 小时前
前端开发中的难题及解决方案玩代码的菜鸟2 小时前
uniapp类似抖音视频滑动晓13133 小时前
JavaScript加强篇——第七章 浏览器对象与存储要点Hockor3 小时前
用 Kimi K2 写前端是一种什么体验?还支持 Claude Code 接入?杨进军3 小时前
React 实现 useMemo海底火旺3 小时前
浏览器渲染全过程解析你听得到113 小时前
揭秘Flutter图片编辑器核心技术:从状态驱动架构到高保真图像处理驴肉板烧凤梨牛肉堡3 小时前
浏览器是否支持webp图像的判断