【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

相关文章

javafx 如何将项目打包为 Windows 的可执行文件exe

《javafx如何将项目打包为Windows的可执行文件exe》文章介绍了三种将JavaFX项目打包为.exe文件的方法:方法1使用jpackage(适用于JDK14及以上版本),方法2使用La... 目录方法 1:使用 jpackage(适用于 JDK 14 及更高版本)方法 2:使用 Launch4j(

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的