- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 JavaScript 新手,这是我第一次使用 HTML5 Canvas ,所以如果这是一个简单的修复,请原谅。
我使用 Canvas 创建了一个 Tic Tac Toe 游戏,每次单击 Canvas 方 block 时都会放置一个 png 或 SVG。我现在正在尝试创建一个撤消按钮,可以删除最后一步。我试图使用clearRect()函数来删除图形,当图形消失时,控制台显示错误“Uncaught TypeError: box.getContext is not a function”...这很奇怪,因为我不'当我使用“box.getContext”将图形放在第一位时,不会出现此错误。
不仅如此,当我尝试再次单击清除的 Canvas 方 block 时,它不允许放置图形......关于为什么会发生这种情况有什么想法吗?
(顺便说一句,我使用 png 表示 X,使用 SVG 表示 O 只是为了练习每种类型的图形)
这是我的 JS:
window.onload = function() {
var num;
var box;
var ctx;
var turn = 1;
var filled;
var symbol;
var winner;
var gameOver = false;
filled = [false, false, false, false, false, false, false, false, false];
symbol = ["", "", "", "", "", "", "", "", ""];
winner = [
[0, 1, 2],
[3, 4, 5],
[6, 7, 8],
[0, 3, 6],
[1, 4, 7],
[2, 5, 8],
[0, 4, 8],
[2, 4, 6]
];
//canvas click + retrieving the box's number
document.getElementById("tic").addEventListener("click", function(e) {
boxClick(e.target.id);
});
function boxClick(numId) {
box = document.getElementById(numId);
ctx = box.getContext("2d"); /*here is where I'm getting the error*/
switch (numId) {
case "square1":
num = 1;
break;
case "square2":
num = 2;
break;
case "square3":
num = 3;
break;
case "square4":
num = 4;
break;
case "square5":
num = 5;
break;
case "square6":
num = 6;
break;
case "square7":
num = 7;
break;
case "square8":
num = 8;
break;
case "square9":
num = 9;
break;
}
//drawing the shapes on the canvases (switch to 0 indexing later)
if (filled[num - 1] == false) {
if (gameOver == false) {
if (turn % 2 != 0) {
var sean_image = new Image();
sean_image.src = "graphics/sean.png";
sean_image.onload = function() {
ctx.drawImage(sean_image, -43, -26);
};
symbol[num - 1] = "X";
} else {
//if number is even (O player)
var square_svg = new Image();
square_svg.src = "graphics/square.svg";
square_svg.onload = function() {
ctx.drawImage(square_svg, 8.5, 8.5);
};
symbol[num - 1] = "O";
}
/* ***this is where I'm trying to implement the undo function */
//undo the last move made
document.getElementById("undo").onclick = function() {
ctx.clearRect(0, 0, box.width, box.height);
filled[num - 1] == false;
symbol[num - 1] = "";
};
}
}
}
};
这是我的 HTML:
<!DOCTYPE html>
<html>
<head>
<title>Tic Tac Toe</title>
<meta charset="utf-8" />
<link rel="stylesheet" type="text/css" href="ticTacToe.css" />
</head>
<body>
<header>
<h1 id="head">Tic Tac Toe Game</h1>
</header>
<h1 id="result"></h1>
<section id="game">
<div id="tic">
<canvas id="square1" width="100" height="100"></canvas>
<canvas id="square2" width="100" height="100"></canvas>
<canvas id="square3" width="100" height="100"></canvas><br />
<canvas id="square4" width="100" height="100"></canvas>
<canvas id="square5" width="100" height="100"></canvas>
<canvas id="square6" width="100" height="100"></canvas><br />
<canvas id="square7" width="100" height="100"></canvas>
<canvas id="square8" width="100" height="100"></canvas>
<canvas id="square9" width="100" height="100"></canvas>
<button id="undo">Undo Move</button>
</div>
</section>
<script type="text/javascript" src="ticTacToe.js"></script>
</body>
</html>
最佳答案
这是因为您将一个点击事件监听器附加到 ID 为 tic
的 div 上。 。因此,如果您单击 tic
内的任何内容div,该事件监听器将触发。因为撤消按钮位于 tic
内部div,当单击它时,该事件监听器将触发并 e.target
将代表被单击的撤消按钮。由于该撤消按钮不是 Canvas 元素,因此 getContext
方法将无法正常工作,您将收到该错误。
因此,您应该使用 id=tic
将该按钮元素移到 div 之外。我会把它放在 tic div 的正下方。
关于javascript - 删除放置在 Canvas 上的最后一个图形,但继续获取 getContext 不是一个函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56858847/
语句 1: [2,4,6,7,8].each do |i| (i % 2 == 0) || (puts "Not even" && break) puts i end 声明 2: [2
我有一张正在显示的卡片,上面有一些信息。我想将其包装在SingleChildScrollView中,因为我还有更多项目要添加到卡中,但是当我这样做时,屏幕只是空白吗?我曾尝试将其作为根(脚手架主体)放
我有一个带有窗体的 View ,该窗体显示ViewModel中ObservableCollection中对象的数据。 ObservableCollection使我可以浏览数据。 ObservableC
如何将时间戳附加文件名放在HDFS中? hadoop fs -put topic_2018-12-15%2016:31:15.csv /user/file_structure/ 最佳答案 您只是在运行
我正在寻求一些帮助,以找出为什么以下叠加函数的运行时间会随着每次连续运行而增加。 据我所知,如果缓冲区中的文本保持不变,则运行时间应该是相同的——即,仅向左/向右移动光标应该不会增加运行时间(但它确实
我有一个事件指示器,它显示在中间。如何将其放置在 View 的左上角? var activityIndicator = UIActivityIndicatorView() func show() {
首先,我想提前感谢所有回答这个问题的人。非常感谢您的帮助。这是我第一次在这里发帖,所以如果我发帖不礼貌,请原谅我。 我的问题是关于方法原型(prototype)的: void copySubtree(
我正在开发一个应该是通用的应用程序,一个适用于 iPad 和 iPhone 的应用程序。我想让他们的界面尽可能相似。在 iPhone 应用程序中,我使用的是选项卡栏 Controller ,其中一个选
我目前正在使用 JS 开发 REST API,但遇到以下问题:该代码有效,但如果我尝试删除、放置或修补不存在的条目,它不会返回错误,但会打印成功消息。这是为什么?获取路由完美运行。 app.route
.a{ width:500px; height:500px; background:yellow; border: 3px dashed black; }
首先,请引用下图: 这基本上是我对布局的想法。 我想要的是: 内容 div 成为“主要焦点”,例如当浏览器 调整大小,它应该留在中间; 当浏览器被调整大小时,我希望这两个图像基本上 位于内容 div
我的应用程序需要使用内存映射并发访问数据文件。我的目标是使其在共享内存系统中可扩展。研究了内存映射文件库实现的源码,想不通: 在多个线程中从 MappedByteBuffer 中读取是否合法? get
我有一个 JDesktopPane 并希望以网格样式显示 JInternalFrames 而无需覆盖框架。框架的尺寸会有所不同,因此应动态分配它们的位置。我可以存储最后放置的框架的坐标,但可以移动、最
根据https://isocpp.org/wiki/faq/dtors#placement-new传递给placement-new的地址必须正确对齐。但它给出的例子似乎与此相矛盾。 char memo
我最近一直在查看 Illumos 源代码,发现了一些奇怪的东西。 在他们的源代码中,函数类型是这样写的: static int outdec64(unsigned char *out, unsigne
您好,我目前正在尝试在我的一张图片旁边放置一个图例,但我在放置时遇到了问题。 我想将图例放在图像的左侧或右侧。这是我当前的代码: .my-legend .legend-title { text-a
根据文档, print 之间的唯一区别和 say 似乎是后者添加了 "\n"(并使用 .gist 进行字符串化)。然而, perl6 -e 'print "del\b\b"' 打印“d”,有效地应用转
所以我试图将我的图像标志放在背景上,但我的背景突然被裁剪,出现了一半的黑屏。如图: 我的 main.dart 代码: import 'package:flutter/material.dart'; i
我正在使用 Azure DevOps 构建 python 轮。我想让它尽可能通用,以便团队中的每个人都可以使用相同的管道来构建自己的 python 轮并将它们部署在一些 databricks 工作区中
在构建标准(非 WordPress)网页时,我通常会在正文末尾之前加载所有 javascript 文件,然后包含页面特定 js 代码的部分。 WorPress 建议使用 wp_enqueue_scri
我是一名优秀的程序员,十分优秀!