当前位置:首页 > VUE

vue实现打字游戏

2026-02-17 17:32:05VUE

Vue 实现打字游戏的核心思路

使用 Vue 的数据绑定和响应式特性,结合键盘事件监听,实现动态文字输入检测与评分功能。关键点包括随机生成文本、实时匹配输入、计时与得分计算。

基础代码结构

<template>
  <div class="typing-game">
    <h3>剩余时间: {{ timeLeft }}秒</h3>
    <p class="target-text">{{ targetText }}</p>
    <input 
      v-model="userInput" 
      @input="checkInput"
      placeholder="开始输入..."
    />
    <p>得分: {{ score }}</p>
  </div>
</template>

核心功能实现

<script>
export default {
  data() {
    return {
      targetText: '',
      userInput: '',
      timeLeft: 60,
      score: 0,
      wordList: ['前端开发', 'Vue框架', '响应式编程', '组合式API', '虚拟DOM']
    }
  },
  mounted() {
    this.generateText();
    this.startTimer();
  },
  methods: {
    generateText() {
      this.targetText = this.wordList[
        Math.floor(Math.random() * this.wordList.length)
      ];
    },

    checkInput() {
      if (this.userInput === this.targetText) {
        this.score += 10;
        this.userInput = '';
        this.generateText();
      }
    },

    startTimer() {
      const timer = setInterval(() => {
        this.timeLeft--;
        if (this.timeLeft <= 0) {
          clearInterval(timer);
          alert(`游戏结束! 最终得分: ${this.score}`);
        }
      }, 1000);
    }
  }
}
</script>

样式优化建议

<style scoped>
.typing-game {
  font-family: Arial;
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}

.target-text {
  font-size: 24px;
  letter-spacing: 1px;
  margin: 20px 0;
}

input {
  width: 80%;
  padding: 10px;
  font-size: 16px;
}
</style>

高级功能扩展

动态难度调整
根据得分动态增加单词长度:

vue实现打字游戏

if (this.score > 30) {
  this.wordList.push('组件化开发思想', '状态管理Vuex');
}

错误高亮显示
添加错误字符样式提示:

<p class="target-text">
  <span 
    v-for="(char, index) in targetText" 
    :class="{ 'error': userInput[index] && userInput[index] !== char }"
  >
    {{ char }}
  </span>
</p>

音效反馈
正确输入时播放提示音:

vue实现打字游戏

const audio = new Audio('correct.mp3');
audio.play();

性能优化建议

使用 Vue 的 computed 属性优化显示逻辑:

computed: {
  displayText() {
    return this.targetText.split('').map((char, i) => {
      return {
        char,
        isCorrect: this.userInput[i] === char
      };
    });
  }
}

游戏结束后禁用输入:

<input :disabled="timeLeft <= 0" />

注意事项

  1. 移动端需要额外处理虚拟键盘事件
  2. 考虑添加游戏重启按钮
  3. 对于长文本建议实现自动滚动
  4. 本地存储可用于保存最高分记录

通过以上方法可以构建一个完整的打字游戏,可根据需求进一步扩展多语言支持、用户等级系统等功能。

标签: 游戏vue
分享给朋友:

相关文章

vue实现aop切面

vue实现aop切面

Vue 实现 AOP 切面编程的方法 在 Vue 中实现 AOP(面向切面编程)可以通过多种方式,以下是几种常见的实现方法: 使用 Vue 混入(Mixins) Vue 的混入机制可以用于实现横切关…

vue实现点击

vue实现点击

实现点击事件的基本方法 在Vue中实现点击事件可以通过v-on指令或@简写方式绑定。以下是常见的点击事件绑定方法: <template> <button v-on:click=…

vue实现表白

vue实现表白

Vue 实现表白页面 使用 Vue 可以快速创建一个动态、交互式的表白页面。以下是一个简单的实现方案: 基础结构 创建一个 Vue 项目或单文件组件,包含以下核心部分: <template&…

vue实现groupbox

vue实现groupbox

Vue 实现 GroupBox 组件 在 Vue 中实现类似 GroupBox 的效果可以通过自定义组件完成。GroupBox 通常是一个带有标题的边框容器,用于将相关控件分组显示。 基本实现方法…

vue实现ssr

vue实现ssr

Vue 实现 SSR(服务端渲染) Vue 的服务端渲染(SSR)允许在服务器端生成完整的 HTML 内容,再发送到客户端,提升首屏加载速度和 SEO 友好性。以下是实现 Vue SSR 的关键步骤和…

vue拖动实现

vue拖动实现

实现 Vue 拖动功能的方法 使用 HTML5 拖放 API 在 Vue 中可以利用 HTML5 的原生拖放 API 实现拖动功能。通过 draggable 属性标记可拖动元素,结合 @dragsta…