HTML+JS实现猜拳游戏的示例代码
作者:海拥 发布时间:2024-04-16 09:31:25
效果图
游戏可以通过这个链接进入
关于JS构建过程
首先,我创建了一个对象,其中包含每种可能性的文本格式(石头、纸、剪刀),然后将图像源也添加到该对象中。
在我制作的 HTML 中:
playerChoiceImg
playerChoiceTxt
computerChoiceImg
computerChoiceTxt
能够修改其中的每个内容。
然后创建了一个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。
2.然后添加了一个setTimeout,它负责动画的时长。
3.在里面我让函数创建一个介于 0-2 之间的随机数,这是选择对象中的元素编号,这将指示计算机的选择。
4.将文本和图像内容更改为所选对象元素的名称和图像源。
5.然后运行 gameRules() 函数(我们稍后会谈到)。
6.更新了每个玩家点数指示器的文本内容。
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


猜你喜欢
- 现在我们常见到有些网站常有这样个功能:有个按钮(如工作职位或省份或地区的选择等等)你一点就跳出一个图层(对话框)让你选择之类的。关闭它就点右
- 关于SQL server2005中插入汉字变成问号的解决办法 1.右击你所建的数据库,点击“属性”,选择“选项”并点击。将其中的排序规则设置
- 前置条件确保mysql的版本是5.7+一、新建mysql表增加json字段二、pojo类package com.cxstar.domain;
- 本文使用TensorFlow实现最简单的线性回归模型,供大家参考,具体内容如下线性拟合y=2.7x+0.6,代码如下:import tens
- 事情是这样的,我写了一个tornado的服务,过程当中我用logging记录一些内容,由于一开始并没有仔细观察tornado自已的日志管理,
- 如何加点盐(salt)?为了加强MD5的安全性,从而加入了新的算法部分即加盐值,加盐值是随机生成的一组字符串,可以包括随机的大小写字母、数字
- 本文实例讲述了ThinkPHP框架下微信支付功能总结。分享给大家供大家参考,具体如下:摘要此文主要为个人解决 ThinkPHP3.2.3 下
- wed的打印方法具我自己懂得知道的有: 1、JQuery插件Jqprint实现 2、JQery打印插件PrintArea实现网页打印 3、C
- 最近打算把我们的微信端用Vue.js重构,为什么选择Vue.js,一是之前使用的是传统的asp.net mvc,多页面应用用户体验比单页面要
- 见下表:序号列类型需要的存储量1TINYINT1 字节2SMALLINT2 个字节3MEDIUMINT3 个字节4INT4 个字节5INTE
- 最近要做一个图像生成的课题,在网上找了一个混合的数据集。这个数据集中一共有360个文件夹,然后文件夹中有6-9张不等的照片,我的目标就是编写
- 实训课期间忙里偷闲的学习了python的selenium包,唯一一点不好是要自己去查英文文档,明摆着欺负我这种英语不好的,想着用谷歌翻译一下
- 一、安装node.js 官网下载下载地址:Download | Node.js(1)下载安装包安装过程很简单,全部next即可。(
- 1.什么是临时表内部临时表是sql语句执行过程中,用来存储中间结果的的数据表,其作用类似于:join语句执行过程中的joinbuffer,o
- 一、绘制折线图使用plot()绘制折线图常用的参数:x:表示x轴的数据y:表示y轴的数据fmt:表示快速设置条样式的格式字符串。label:
- Python 提供了如下两个函数来检查类型:issubclass(cls, class_or_tuple):检查 cls 是否为后一个类或元
- 一、初识正则表达式正则表达式 是一个特殊的字符序列,一个字符串是否与我们所设定的这样的字符序列,相匹配快速检索文本、实现替换文本的操作jso
- 1. 正文1.1下载和安装软件本文我会通过miniconda+jupyter lab的形式带大家安装opencv;有很多朋友会问为什么不是a
- JavaScript闭包,是JS开发工程师必须深入了解的知识。3月份自己曾撰写博客《JavaScript闭包》,博客中只是简单阐述了闭包的工
- 安装pip install pyshp引入import shapefile读取sf=shapefile.Reader("{路径名}