【Vue】第一个小项目“怪物杀手”

2024-04-02 18:12

本文主要是介绍【Vue】第一个小项目“怪物杀手”,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现效果:

  • 四个功能按键:攻击,技能,治疗,投降
  • 战斗日志:记录玩家和怪物的对战细节
  • 至少有一个血条归零时判断胜者(或平局),并出现重新开始游戏按钮
    在这里插入图片描述
    在这里插入图片描述

Javascript部分:

function getRandomValue(min, max) {return Math.floor(Math.random() * (max - min)) + min
}const app = Vue.createApp({data() {return {playerHealth: 100,monsterHealth: 100,currentRound: 0,winner: null,logMessages: [],}},computed: {//怪物血条计算monsterBarWidth() {if (this.monsterHealth < 0) {return { width: "0%" }}return "width:" + this.monsterHealth + "%"},//玩家血条计算playerBarWidth() {if (this.playerHealth < 0) {return { width: "0%" }}return "width:" + this.playerHealth + "%"},mayUseSpecialAttack() {return this.currentRound % 3 !== 0},},watch: {playerHealth(value) {if (value <= 0 && this.monsterHealth <= 0) {// 平局this.winner = "draw"} else if (value <= 0) {// 玩家失败this.winner = "monster"}},monsterHealth(value) {if (value <= 0 && this.playerHealth <= 0) {// 平局this.winner = "draw"} else if (value <= 0) {// 玩家获胜this.winner = "player"}},},methods: {//游戏重开 吧startGame() {this.playerHealth = 100this.monsterHealth = 100this.currentRound = 0this.winner = nullthis.logMessages = []},//普通攻击,伤害值5~12attackMonster() {this.currentRound++const attackValue = getRandomValue(5, 12)this.monsterHealth -= attackValuethis.addLogMessage("player", "attack", attackValue)this.attackPlayer()},//怪物攻击,伤害值8~15attackPlayer() {const attackValue = getRandomValue(8, 15)this.playerHealth -= attackValuethis.addLogMessage("monster", "attack", attackValue)},//技能,伤害值10~25,使用后有两回合冷却specialAttackMonster() {this.currentRound++const attackValue = getRandomValue(10, 25)this.monsterHealth -= attackValuethis.addLogMessage("player", "attack", attackValue)this.attackPlayer()},//治疗,8~20治疗值healPlayer() {this.currentRound++const healValue = getRandomValue(8, 20)if (this.playerHealth + healValue > 100) {this.playerHealth = 100} else {this.playerHealth += healValue}this.addLogMessage("player", "heal", healValue)this.attackPlayer()},//投降surrender() {this.winner = "monster"},//对战日志,最新战况插入数组头部addLogMessage(who, what, value) {this.logMessages.unshift({actionBy: who,actionType: what,actionValue: value,})},},
})app.mount("#game")

Html部分

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Vue Basics</title><linkhref="https://fonts.googleapis.com/css2?family=Jost:wght@400;700&display=swap"rel="stylesheet"/><link rel="stylesheet" href="styles.css" /><script src="https://unpkg.com/vue@3/dist/vue.global.js"></script><script src="app.js" defer></script></head><body><header><h1>Monster Slayer</h1></header><div id="game"><!-- 怪物血条 --><section id="monster" class="container"><h2>Monster Health</h2><div class="healthbar"><div class="healthbar__value" :style="monsterBarWidth"></div></div></section><!-- 玩家血条 --><section id="player" class="container"><h2>Your Health</h2><div class="healthbar"><div class="healthbar__value" :style="playerBarWidth"></div></div></section><!-- winner中有值(monster||player||draw)时出现游戏结束面板 --><section class="container" v-if="winner"><h2>Game Over!</h2><h3 v-if="winner == 'monster'">You lost!</h3><h3 v-else-if="winner == 'player'">You won!</h3><h3 v-else>It`s a draw!</h3><button @click="startGame">Star New Game</button></section><!-- winner还没出现,则显示四个功能按钮 --><section id="controls" v-else><button @click="attackMonster">ATTACK</button><button :disabled="mayUseSpecialAttack" @click="specialAttackMonster">SPECIAL ATTACK</button><button @click="healPlayer">HEAL</button><button @click="surrender">SURRENDER</button></section><!-- 对战日志 --><section id="log" class="container"><h2>Battle Log</h2><ul><li v-for="logMessage in logMessages"><span:class="{'log--player': logMessage.actionBy === 'player', 'log--monster': logMessage.actionBy === 'monster'}">{{ logMessage.actionBy === 'player' ? 'Player' : 'Monster'}}</span><span v-if="logMessage.actionType === 'heal'">heals himself for<span class="log--heal">{{ logMessage.actionValue }}</span></span><span v-else>attacks and deals<span class="log--damage">{{ logMessage.actionValue }}</span></span></li></ul></section></div></body>
</html>

这篇关于【Vue】第一个小项目“怪物杀手”的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/870704

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js