- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 JavaScript 世界的新手,希望您能在基本编码方面为我提供帮助。
如何仅在一个函数中制作我的井字游戏(X 和 O 选择)?我还想选择单元格而不是隐藏按钮。
我尝试了主要功能:
if (document.getElementById("cell1").checked = true)
if (document.getElementById("cell1").onclick= click)
但没有成功。
这是我试图用它来完成井字棋的功能
var nextTurn = 'X'
function chose1() {
if (document.getElementById("Hidden1").checked = true) {
if (document.getElementById('cell1').innerText == "") {
document.getElementById('cell1').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden2").checked = true) {
if (document.getElementById('cell2').innerText == "") {
document.getElementById('cell2').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden3").checked = true) {
if (document.getElementById('cell3').innerText == "") {
document.getElementById('cell3').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden4").checked = true) {
if (document.getElementById('cell4').innerText == "") {
document.getElementById('cell4').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden5").checked = true) {
if (document.getElementById('cell5').innerText == "") {
document.getElementById('cell5').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden6").checked = true) {
if (document.getElementById('cell6').innerText == "") {
document.getElementById('cell6').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden7").checked = true) {
if (document.getElementById('cell7').innerText == "") {
document.getElementById('cell7').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden8").checked = true) {
if (document.getElementById('cell8').innerText == "") {
document.getElementById('cell8').innerText = nextTurn;
changeTurn();
}
}
else if (document.getElementById("Hidden9").checked = true) {
if (document.getElementById('cell9').innerText == "") {
document.getElementById('cell9').innerText = nextTurn;
changeTurn();
}
}
}
function changeTurn() {
if (nextTurn == 'X') {
nextTurn = 'O';
} else {
nextTurn = 'X';
}
}
这些是我调用函数所用的表。
<table border="10" cellpadding="40">
<tbody>
<tr>
<td id="cell1" onclick="chose1()">
</td>
<input id="Hidden1" type="hidden" />
<td id="cell2" onclick="chose2()">
<input id="Hidden2" type="hidden" />
</td>
<td id="cell3" onclick="chose3()">
<input id="Hidden3" type="hidden" />
</td>
</tr>
<tr>
<td id="cell4" onclick="chose4()">
<input id="Hidden4" type="hidden" />
</td>
<td id="cell5" onclick="chose5()">
<input id="Hidden5" type="hidden" />
</td>
<td id="cell6" onclick="chose6()">
<input id="Hidden6" type="hidden" />
</td>
</tr>
<tr>
<td id="cell7" onclick="chose7()">
<input id="Hidden7" type="hidden" />
</td>
<td id="cell8" onclick="chose8()">
<input id="Hidden8" type="hidden" />
</td>
<td id="cell9" onclick="chose9()">
<input id="Hidden9" type="hidden" />
</td>
</tr>
</tbody>
</table>
这是我的获胜组合函数,但效果不佳,我尝试了几种方法:
function WinningCombinations(){
if (document.getElementById("cell1").innerText == "X")
(document.getElementById("cell2").innerText == "X")
(document.getElementById("cell3").innerText == "X")
{
alert("Congratulations X you won.");
}
if (document.getElementById("cell4").innerText == "X")
(document.getElementById("cell5").innerText == "X")
(document.getElementById("cell6").innerText == "X")
{
alert("Congratulations X you won.");
}
}
底线我正在努力实现以下目标:
chose1()
不起作用,因此它会将 X 或 O 赋予新单击的单元格。WinningCombinations()
,以便它与我的基本编码保持一致。 非常感谢您的帮助。
最佳答案
首先,你的功能太重复了。也许我们可以修复它:
function chose1() {
for (var i=1; i<10; i++) {
if (document.getElementById("Hidden" + i).checked = true) { // whoops
var cell = document.getElementById('cell' + i);
if (cell.innerText == "") {
cell.innerText = nextTurn;
changeTurn();
}
break;
}
}
}
通过更少的行数,可以更容易地发现该函数设置 cell.checked = true
,而不是检查 cell.checked === true
。
您还可以内联changeTurn函数:
nextTurn = nextTurn === 'X' ? 'O' : 'X';
其次,井字棋有 8 个获胜组合,我想你忘记了其中一些。
关于javascript - 如何将 Tic Tac Toe 函数 "Chose function"组合在一个函数中并选择单元格而不是隐藏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19953724/
我是初学者,所以我的代码很乱。我还没有完整地评论这个游戏,所以如果你需要澄清一些变量,我可以给你。 (顺便说一句,这是一个要求制作井字游戏的c++项目) 我的主要问题是,我将如何重复我的棋盘(每次有人
我正在为C的Tic Tac Toe代码编写一个简单的游戏。我已经完成了大部分代码,但是我希望AI永不丢失。 我已经阅读了有关minimax算法的信息,但我不理解。如何使用此算法使计算机获胜或平局,但永
在MATLAB中,我想对一个别人写的函数进行计时,他们的函数内部可能使用了tic/toc。我想要我自己的 tic/toc。但如果内部函数调用 tic,则外部计时器会重置。 我怎样才能避免这种情况?我不
在MATLAB中,我想对一个别人写的函数进行计时,他们的函数内部可能使用了tic/toc。我想要我自己的 tic/toc。但如果内部函数调用 tic,则外部计时器会重置。 我怎样才能避免这种情况?我不
我现在想用我的代码做两件事。1) 检查获胜者2) 不让双方玩家在同一个位置进入eg.如果player1已经在board[0][0]='X'处输入了value,player2再次进入board[0][0
我在我的 Matlab 项目中的很多地方都使用了 tic-toc 函数。输出时间可以是331.5264 或1234.754 秒 等。我可以输出这种分钟格式吗?例如。 5 分 30.6 秒?谢谢! 最佳
我的代码(或者更确切地说,其他人的代码)有一个奇怪的问题。我正在调试并试图弄清楚为什么我们的时间显示错误。 无论如何,这是打印时间的代码:
我一直在开发一个简单的井字棋游戏,但遇到了一堵砖墙。 虽然大多数游戏功能都已到位,但我缺少适当放置计算机图 block 所需的关键算法。 我需要一种算法,可以搜索 3x3 的瓷砖网格,并在网格中搜索计
我正在用这种格式从数据文件中绘制一个 gnuplot 图表: 01 value_1_1 value_2_1 02 value_1_1 value_2_1 ... 01 value_1_n value_
在 gnuplot 中,如何在 y 轴上的每个 tic 标记处在整个图形上绘制水平条?就像一种特定点在哪里的视觉指示器。 (抱歉,如果这很简单,但谷歌搜索无果而终) 最佳答案 见 set grid命令
感谢这里人们的帮助,我成功地禁用了点击 div 并在已经使用 $(".pos").addClass('already-played'); 选择它们时覆盖它们; 以及 CSS 中的这个: .已经播放{
我正在使用 gnuplot 绘制大量绘图。由于每个图的数据范围(x 轴和 y 轴)都是可变的,因此我需要让 gnuplot 自动设置范围和控制。但是,我需要在绘图下方放置一个定义的网格,水平线各 1/
我有一个井字棋游戏,其中用户(x)玩CPU(o)。游戏开始时,CPU 将 (o) 放置在中心,并在用户之后移动到随机位置。游戏设置为循环,但一旦出现获胜者,它就会重置,并且不会显示“你赢/输的横幅”。
我是 gnuplot 新手,正在尝试为项目创建堆叠直方图。我遇到的问题是,我无法将 ticlabels 放在 x 轴上(即使可以,它们也没有以整齐的方式格式化)。我的gp文件如下: 这是我的数据文件的
我试图在没有人工智能的情况下实现井字棋游戏。不知怎的,我的点击功能会自动触发。您能帮我理解为什么点击功能会自动触发吗?这是 HTML 代码片段。 Tic Tac Toe Gam
我一直在疯狂地寻找这个问题的答案。如何设置 gnuplot 上抽动之间的距离?目前我的情节中的抽搐被挤得太紧了。我希望它们更加分散。 这是一个例子: 我有一个如下所示的图表: 100 ——
我正在制作一个井字游戏程序。我计划将 minimax 与它一起使用。我制作了一棵树,其中包含所有可能的游戏序列的空间,并且我正在寻找一种方法来填充它。我目前有这种类型: typedef struct
我在完成这项学校作业时遇到了问题。我想实现一种方法,其中代码显示 //call method to check for Winner,在每轮后检查获胜者。 我不确定该怎么做。我尝试过各种不同的方法。然
我正在编写一些计算时间很重要的代码。我使用 tic toc 函数和 profiler 来测量时间。它们之间有什么区别? 对于我的一段代码,tic toc 函数说明例如时间是 3 秒,但是我的所有代码行
我正在尝试遵循本教程: https://www.youtube.com/watch?v=Db3cC5iPrOM 2:59 我听不懂他在说什么。 我不明白为什么他在构造函数(public static
我是一名优秀的程序员,十分优秀!