`摸鱼决策轮盘`【vue3+ts前端实战小项目】

纠结要不要继续卷?点一下,轮盘替你做决定。

vue 复制代码
<script setup lang="ts">
import { ref, computed } from 'vue'
const input = ref('写文档,改Bug,摸鱼5分钟,喝水,拉伸,看技术文章')
const items = computed(() => input.value.split(',').map(s => s.trim()).filter(Boolean))
const idx = ref(0), rolling = ref(false), msg = ref('点击开始')
let timer: number | null = null
function start() {
  if (rolling.value || items.value.length < 2) return
  rolling.value = true; msg.value = '命运加载中...'
  timer = window.setInterval(() => idx.value = (idx.value + 1) % items.value.length, 80)
}
function stop() {
  if (!rolling.value || !timer) return
  window.clearInterval(timer); timer = null; rolling.value = false
  const pick = items.value[idx.value]
  msg.value = `今日指令:${pick}`
}
function addPreset() { input.value += ',下楼晒太阳' }
</script>

<template>
  <main class="box">
    <h2>摸鱼决策轮盘</h2>
    <textarea v-model="input" rows="3" />
    <p class="pick">{{ items[idx] || '请至少输入2项' }}</p>
    <p>{{ msg }}</p>
    <button @click="start" :disabled="rolling">开始</button>
    <button @click="stop" :disabled="!rolling">停止</button>
    <button @click="addPreset">加一个选项</button>
  </main>
</template>

<style scoped>
.box{max-width:520px;margin:32px auto;display:grid;gap:10px}
textarea{width:100%;padding:8px}.pick{font-size:28px;font-weight:700;color:#42b883}
button{margin-right:8px}
</style>

完整资源包点击下载,可直接npm运行的。

相关推荐
夜焱辰8 小时前
浏览器端 Agent 的文件版本管理:不用 Git,基于 OPFS + SQLite 自己造了一个
前端·人工智能
梦想的颜色8 小时前
TypeScript 完全指南(下):从类型体操到生产级配置
前端·javascript·typescript
Hi~晴天大圣10 小时前
npm使用介绍
前端·npm·node.js
888CC++11 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
喵个咪11 小时前
基于 Taro 的 Headless CMS 多端前端架构:技术解析与二次开发导引
前端·react.js·taro
狂炫冰美式11 小时前
你还在古法PPT吗,试试HTML呢?免费编辑导出工具给 xdm 放这了
前端·后端·github
万少12 小时前
未来组织的分水岭不是员工数量,而是人才密度
前端·后端·面试
任磊abc12 小时前
nextjs16配置eslint+prettier
前端·eslint·nextjs·prettier
x***r15112 小时前
Another-Redis-Desktop-Manager.1.3.7安装步骤详解(附Redis可视化连接与Key管理教程)
前端·bootstrap·html
Captaincc12 小时前
你真的知道自己把 AI 用在了哪里吗?这是 Vibe Usage 想回答的问题
前端·vibecoding