- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了一个基本的回合制战斗游戏,它在 Chrome 和 Firefox 中运行得非常好。然而,尽管所有其他代码都完美运行,但它不会在 Internet Explorer 中加载任何图像。我已将其范围缩小到图像加载功能的问题。这是有问题的代码片段:
// image load functions
function loadSpriteSheet() {
gv.spriteSheet = new Image();
gv.spriteSheet.src = 'Sprite Sheet v5.png';
}
function loadGUI() {
gv.GUI = new Image();
gv.GUI.src = 'gui.png';
}
function loadBackgrounds() {
gv.backgrounds = new Image();
gv.backgrounds.src = 'backgrounds.png';
}
// drawing functions
function drawArenaFloor() {
// bunch of code to draw the floor of the arena in tiles
}
function drawUnderlay() {
// bunch of code to draw stuff like player selector box
}
function drawArenaWalls() {
// bunch of code to draw the walls of the arena in tiles
}
// main code body here
// this is the 'problem' function
function resizeCanvas() {
// runs each time the DOM window resize event fires. resets the canvas dimensions to match window, then draws the new borders accordingly
// bunch of code here to determine screen size, arena size etc.
// load all the images for the game
loadBackgrounds();
loadSpriteSheet();
loadGUI();
// this is the 'problem' code
gv.spriteSheet.onload = function() {
drawArenaFloor();
drawUnderlay();
drawArenaWalls();
}
}
现在有趣的事情来了。如果我删除 onload 处理程序,图像有时会在 IE 中加载,但从不在 chrome/firefox 中加载:
// this is the 'problem' code, revised to *sometimes* work in IE (basically by commenting out the onload handler)
// gv.spriteSheet.onload = function() {
drawArenaFloor();
drawUnderlay();
drawArenaWalls();
// }
这个真的把我难住了。有什么想法吗?
以下是所要求的完整 HTML 源代码:
<!DOCTYPE html>
<!-- Copyright 2013-2014 -->
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Arena</title>
<link type="text/css" rel="stylesheet" href="style.css"/>
<script src="app.js"></script>
</head>
<body>
<div id="Top section">
<canvas id="shopButtonCanvas" class = "topButton"></canvas>
<input type="button" alt="Shop" id="Shop button" class="topButton" onclick="shop()">
<div>
<p id="Display size">XxY, A/R</p>
</div>
<div id = "Ad container" class="xxx" onclick="clickOnAd()">
</div>
<canvas id="closeButtonCanvas" class = "topButton"></canvas>
<input type="button" alt="Close" id="Close button" class="topButton" onclick="closeButton()">
</div>
<div id = "Main" align="center">
<canvas id="Arena floor"></canvas>
<canvas id="Underlay"></canvas>
<canvas id="Arena walls"></canvas>
<canvas id="Arena">Your browser does not support HTML5 Canvas.</canvas>
<div id="Status bars" align="left">
<canvas id="detailButtonCanvas" class="button"></canvas>
<input type="button" alt="Player Detail" id="Detail button" class="button" onclick="detailButton()">
<canvas id="Player health bar"></canvas>
<div id="Round counter">
<div id="Round display">
<span><b>Round: </b><span id="Current round"></span> / <span id="Max rounds"></span></span>
</div>
<div id="Turn display">
<span id="Turn outer"><b>Turn: </b></span><span id="Turn" class="player"></span>
</div>
<div id="Turn arrow"></div>
</div>
<canvas id="enemyDetailButtonCanvas" class="button"></canvas>
<input type="button" alt="Enemy Detail" id="Enemy detail button" class="button" onclick="detailButton()">
</div>
<div id="Player stats">
<h3 id="Player team name"><u>Player Team Stats</u></h3>
<b>Players: </b><span id="Player living pieces"></span>
<br> <b>Health: </b><span id="Player team health"></span>
<br> <b>Stamina: </b><span id="Player team stamina"></span>
<br> <b>Moves: </b><span id="Player team moves"></span>
<h3 id="Player name"><u>Player Stats</u></h3>
<b>Level: </b><span id="Player level"></span>
<br> <b>Health: </b><span id="Player health"></span>
<br> <b>Stamina: </b><span id="Player stamina"></span>
<br> <b>Armor: </b><span id="Player AC"></span>
<br> <b>Weapon: </b><span id="Player weapon"></span>
<br> <b>Action: </b><span id="Player action"></span>
</div>
<div id="Enemy stats">
<h3 id="Enemy team name"><u>Enemy Team Stats</u></h3>
<b>Enemies: </b><span id="Enemy living pieces"></span>
<br> <b>Health: </b><span id="Enemy team health"></span>
<br> <b>Stamina: </b><span id="Enemy team stamina"></span>
<br> <b>Moves: </b><span id="Enemy team moves"></span>
<h3 id="Enemy name"><u>Enemy Stats</u></h3>
<b>Level: </b><span id="Enemy level"></span>
<br> <b>Health: </b><span id="Enemy health"></span>
<br> <b>Stamina: </b><span id="Enemy stamina"></span>
<br> <b>Armor: </b><span id="Enemy AC"></span>
<br> <b>Weapon: </b><span id="Enemy weapon"></span>
<br> <b>Action: </b><span id="Enemy action"></span>
</div>
<div id="Container" align="center">
<canvas id="healthButtonCanvas" class="containerButton"></canvas>
<input type="button" alt="Health" id="Health button" class="containerButton" onclick="healthIncrease()">
<canvas id="staminaButtonCanvas" class="containerButton"></canvas>
<input type="button" alt="Stamina" id="Stamina button" class="containerButton" onclick="staminaIncrease()">
<canvas id="defendButtonCanvas" class="containerButton"></canvas>
<input type="button" alt="Defend" id="Defend button" class="containerButton" onclick="defend()">
<canvas id="switchWeaponButtonCanvas" class="containerButton"></canvas>
<input type="button" alt="Switch Weapon" id="Switch weapon button" class="containerButton" onclick="switchWeapon()">
<canvas id="endTurnButtonCanvas" class="containerButton"></canvas>
<input type="button" value="End Turn" id="End turn button" class="containerButton" onclick="endTurnButton()">
</div>
</div> <!-- Close the main div -->
<div id = "Test" align="center" class = "test"></div>
<div id="Text area" align="left">
<p id="Result">Loading...</p>
<canvas id="messageLogButtonCanvas"></canvas>
<input type="button" value="Message Log" id="Message log button" class="message" onclick="messageLog()">
</div>
</body>
</html>
最佳答案
这可能看起来很荒谬..但你可以尝试这个:
gv.spriteSheet.onload = function() {
setTimeout(function(){
drawArenaFloor();
drawUnderlay();
drawArenaWalls();
},500);
}
我多次使用超时在 IE 中解决了这些问题,似乎 IE 以其他方式处理事件。
关于javascript - 图像加载功能在 Internet Explorer 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25091589/
像其他人一样,我需要在 Internet Explorer 6 和 Internet Explorer 7 上测试我的代码。现在,Internet Explorer 8 为开发人员提供了一些很棒的工具
我已经浏览了几个小时的注册表,但似乎无法找到控制 Internet Explorer 临时 Internet 文件设置的注册表。我想从自动更改为其他内容。 最佳答案 HKCU\Software\Mic
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicate: Running Internet Explorer 6, Internet Explorer 7, and Int
作为一名开发者,我发现新的 Internet Explorer 版本完全是一场噩梦。我关闭了 Windows 功能,但无法安装 Internet Explorer 10 。它说它已经安装,但事实并非如
是否有任何分析器工具可以调试DOM中的哪个javascript /对象导致Internet Explorer挂起/崩溃。 CPU使用率将超过60%,我想知道其背后的原因,是哪个脚本/ Flash Ob
我正在尝试确定Internet Explorer上TTF字体格式的支持状态。 (我手头没有任何Windows计算机可以尝试。)The table at caniuse指出,从版本9开始的IE支持TTF
是否可以在 Internet Explorer 中切换多个版本的 JDK/JRE? 想要使用 jdk 1.4、jdk 5 和 jdk 6。 谢谢,迈克尔 最佳答案 据我所知,这并不容易做到,因为 IE
这应该是IE8下载问题的老问题了。我使用 PHP 来设置响应头,如: header("Pragma: public"); header("Expires: 0"); header("Content-t
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicate: Running Internet Explorer 6, Internet Explorer 7, and Int
我正在使用新的Internet Explorer 11开发人员工具将文档模式切换为“8”,但条件注释仍然被忽略,也就是说,它们没有被正确解析并且表现得像普通注释。因此,浏览器不会请求/加载条件注释内的
我在我的一个站点上遇到 Internet Explorer 6 问题,我真的希望我安装它而不是 Internet Explorer 7。有没有一种快速的方法来做到这一点? 最佳答案 下载Microso
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
如何访问 Internet Explorer 运行实例的经典 Internet Explorer COM 自动化对象?也就是说,如果我在多个窗口中打开 Internet Explorer,如何从 Po
string filename = Server.UrlPathEncode(Path.GetFileName(_Filename))); Response.AddHeader("Content-Di
当我尝试使用 Apache 2.2 在 Windows7(64 位)上的 IE9 或 IE10 中打开 localhost 时,解析 URL 需要很长时间。其他浏览器没有问题并立即解析 URL,只有
我有一个批处理文件,必须启动 Internet Explorer 并打开 www.google.com .当整个页面加载完成时,它应该终止 IE 进程,即关闭该系统中的所有 IE 实例。我的批处理文件
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6 个月前关闭。 Improve t
基本上,无论我使用 IE 访问哪个网站,我都可以看到那些黑色/白色形状,一旦我将鼠标移到它们上,它们就会消失。 想知道是否有人知道可能导致这种情况的原因? 另外:http://imageshack.c
我检查了所有注册表,但找不到所有已安装扩展的列表。 此时,IE 扩展/加载项的任何一般位置都会有所帮助。 最佳答案 取自 here : 浏览器帮助对象 - 旨在增强浏览器功能的浏览器插件。 条目可以在
这是一个两部分的问题。我正在构建一个网页,我需要知道: 有没有办法检测 IE 是否启用了平滑滚动(如果是,如何)? 有没有办法强制 IE 关闭我网页的平滑滚动功能? 明确地说,我不是在问如何关闭整个计
我是一名优秀的程序员,十分优秀!