HTML+JS实现猜拳游戏的示例代码

作者:海拥 时间:2024-04-16 09:31:25 

效果图

HTML+JS实现猜拳游戏的示例代码

游戏可以通过这个链接进入

关于JS构建过程

首先,我创建了一个对象,其中包含每种可能性的文本格式(石头、纸、剪刀),然后将图像源也添加到该对象中。

在我制作的 HTML 中:

  • playerChoiceImg

  • playerChoiceTxt

  • computerChoiceImg

  • computerChoiceTxt

HTML+JS实现猜拳游戏的示例代码

能够修改其中的每个内容。

然后创建了一个points变量,它将存储每个玩家(玩家和计算机)的分数。

之后,我需要一个介于 1 和 3 之间的随机生成的数字来指示计算机的选择。

// 变量
const choices = [{
       id: 1,
       name: "石头",
       image: "./img/rock.png"
   },{
       id: 2,
       name: "布",
       image: "./img/paper.png"
   },{
       id: 3,
       name: "剪刀",
       image: "./img/scissors.png"
   }]

let playerPoints = document.querySelector(".playerPoints")
let computerPoints = document.querySelector(".computerPoints")
let playerChoiceImg = document.querySelector("#playerChoiceImg")
let playerChoiceTxt = document.querySelector("#playerChoiceTxt")
let computerChoiceImg = document.querySelector("#computerChoiceImg")
let computerChoiceTxt = document.querySelector("#computerChoiceTxt")
let buttons = document.querySelectorAll(".btn")
let points = [0, 0]
let randomNumber;

老实说我给这些对象一个ID,但没有在项目中使用它们。我只是在选择时使用了每个索引。

添加事件 *

这里我使用 forEach() 方法将事件 * 附加到按钮上。

这个事件 * 将完成大部分工作。

// 事件监听
buttons.forEach((button) => {
   button.addEventListener("click", () => {
       if (button.textContent === "石头") {
           playerChoiceImg.src = choices[0].image;
           playerChoiceTxt.textContent = choices[0].name;
       } else if (button.textContent === "布") {
           playerChoiceImg.src = choices[1].image;
           playerChoiceTxt.textContent = choices[1].name;
       } else if (button.textContent === "剪刀") {
           playerChoiceImg.src = choices[2].image;
           playerChoiceTxt.textContent = choices[2].name;
       }
       getComputerChoice();
       console.log(points);
   })
})

正如大家在上面代码中看到的那样,我使用 if-else 语句以及根据按钮的 textContent 来定义哪个按钮执行什么操作。

if-else 语句:

如果按钮本身有“石头”文字,那么会在playerChoiceTxt中显示“石头”,同时将playerChoiceImg的图像源更改为存储在对象中的图像源,其他 2 个也是如此。

之后,我创建了计算机的选择功能,如下所示:

// 选择功能
function getComputerChoice() {
   computerChoiceImg.src = "./img/gif.gif"
   setTimeout(() => {
       randomNumber = Math.floor(Math.random() * 3);
       computerChoiceImg.src = choices[randomNumber].image;
       computerChoiceTxt.textContent = choices[randomNumber].name;
       gameRules();
       playerPoints.textContent = points[0];
       computerPoints.textContent = points[1];
       whoWon();
   }, 1000);
}

1.我用石头、剪纸和剪刀的 3 幅图创建了一个循环 gif。

HTML+JS实现猜拳游戏的示例代码

2.然后添加了一个setTimeout,它负责动画的时长。

3.在里面我让函数创建一个介于 0-2 之间的随机数,这是选择对象中的元素编号,这将指示计算机的选择。

4.将文本和图像内容更改为所选对象元素的名称和图像源。

5.然后运行 gameRules() 函数(我们稍后会谈到)。

6.更新了每个玩家点数指示器的文本内容。

HTML+JS实现猜拳游戏的示例代码

7.检查每个函数调用的分数,以检查是否有人获胜。(whoWon() 函数)

函数 gameRules()

function gameRules() {
   if (playerChoiceTxt.textContent === choices[0].name && computerChoiceTxt.textContent === choices[1].name) {
       points[1]++;
   } else if (playerChoiceTxt.textContent === choices[1].name && computerChoiceTxt.textContent === choices[2].name) {
       points[1]++;
   } else if (playerChoiceTxt.textContent === choices[2].name && computerChoiceTxt.textContent === choices[0].name) {
       points[1]++;
   } else if (playerChoiceTxt.textContent === computerChoiceTxt.textContent) {
       console.log("draw");
   } else {
       points[0]++;
   }
}

这个函数检查玩家的选择并检查计算机选择是否可以战胜它。我已经根据游戏规则设置了这些 if-else 语句。如果计算机赢了,则计算机的分数加 1,否则玩家的分数加 1。

函数 whoWon()

又是 if-else 语句

function whoWon() {
   if (points[0] === 10) {
       alert("你干掉了AI成功取得胜利!")
       points = [0, 0];
   } else if (points[1] === 10) {
       alert("你被人工智能打败了!")
       points = [0, 0];
   }
}

最后只要检查点数组是否有人已经达到 10 分,如果是,则将这些点重置为其初始值。

完整代码

来源:https://juejin.cn/post/7081172645433049096

标签:JS,猜拳,游戏
0
投稿

猜你喜欢

  • pytorch如何定义新的自动求导函数

    2021-02-10 20:14:49
  • python实现读取excel文件中所有sheet操作示例

    2022-04-25 15:00:36
  • SQL Server 2019自定义安装教程

    2024-01-12 21:14:22
  • web项目中golang性能监控解析

    2024-02-18 17:28:23
  • Python虚拟机字节码教程之控制流实现详解

    2023-01-09 09:56:53
  • 交互设计实用指南系列(8)—深广度平衡

    2010-02-01 12:59:00
  • 基于python3 pyQt5 QtDesignner实现窗口化猜数字游戏功能

    2022-02-05 00:56:54
  • 基于tensorflow权重文件的解读

    2023-11-04 02:05:35
  • SQL2005 ROW_NUMER实现分页的两种常用方式

    2024-01-20 05:37:42
  • matplotlib绘制折线图的基本配置(万能模板案例)

    2022-09-06 18:06:17
  • python中datetime模块中strftime/strptime函数的使用

    2023-11-15 15:02:46
  • 基于Vue+Openlayer实现动态加载geojson的方法

    2024-04-27 16:12:22
  • PPOCRLabel标注的txt格式如何转换成labelme能修改的json格式

    2021-08-31 06:01:45
  • Docker构建python Flask+ nginx+uwsgi容器

    2023-07-25 06:36:43
  • node.js回调函数之阻塞调用与非阻塞调用

    2024-05-05 09:21:26
  • centos 6.5下 mysql-community-server. 5.7.18-1.el6安装

    2024-01-15 14:54:26
  • 解决Pytorch dataloader时报错每个tensor维度不一样的问题

    2022-10-06 20:08:56
  • python使用心得之获得github代码库列表

    2023-12-01 21:31:51
  • python买卖股票的最佳时机(基于贪心/蛮力算法)

    2022-12-26 14:44:24
  • Pycharm 2019 破解激活方法图文详解

    2023-10-31 10:49:04
  • asp之家 网络编程 m.aspxhome.com