- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先我想说的是,此时我真的不需要任何代码。最有可能的是,我只需要一个起点。
我正在尝试构建一个浏览器扩展(chrome),它允许我使用键盘按键来导航一个特定页面。
此页面位于游戏中 ( http://www.galatium.net/Faerlyn/forest.php?view=explore )如果你想看,你必须注册,所以我只会描述它。
这是一个由可点击框组成的 3x3 网格(不是真正的按钮...)。中间的框是不可点击的。
游戏创建者使用 JS(onClick 事件)来导航区域(交互式森林)。
我想做的是将每个框的 onlick 事件绑定(bind)到键盘按键。
基本上我们有:
北=8
南=2
东=6
西=4
西北=7
西南=1
东北=9
东南=3
数字键盘方向
现在,通过各种研究,我了解到我需要使用内容脚本将我的 JavaScript 注入(inject)到我希望其运行的网页上。
问题是每个框都是由这行代码决定的:
<td bgcolor="#002900" style="cursor: pointer; background-color: rgb(0, 41, 0);" onmouseover="style.backgroundColor='#003300'" onmouseout="style.backgroundColor='#002900'" onclick="window.location='?action=move&x=332&y=96'"> </td>
该行本身并不太复杂,但我习惯了 OOP,而且我不明白如何引用它。
这就是我的想法:
假设这是我的 JS 函数:
function DoSomething() {}
$(document).ready(function() {
$("body").keydown(function(event) {
if(event.keyCode == arrow.left) {
DoSomething();
}
}
}
代码中不包含它,但会有一个 GET 来获取当前的 X 和 Y 值,然后根据所选方向加或减 1。
所以,DoSomething()
将有一个名为“方向”的参数。
然后在按键事件中,我的函数将“单击”与我的函数的 X 和 Y 相匹配的框。
所以,对于北,首先我有一个找到 x=10 和 y=10 的 get 。然后知道我已经点击了“8”,它将设置 x=10 和 y=10+1。然后,该函数将找到参数与我的函数的参数匹配的框,然后“单击”它。
我这样做对吗? (或者有更简单的方法吗?)
~哈姆扎
最佳答案
您正在使用 <table>
在此表中有 3 <tr>
在每个 <tr>
有3个容器
为您提供 13 个可选目标。
使用 jQuery 你可以做几件事:
您可以为每个人分配一个唯一的 id
或class
keypress() 操作/选择数字键盘上的 96 到 105 的键代码。您可以将操作映射到键盘。
不清楚你的行动是否会在移动中发生。
示例:您是否正在处理弹出到屏幕上的某些内容,然后您必须快速定向移动它?方向键,但没有提交按键。
示例 2:您有一个像拼图一样的可移动价格网格,但您必须在确定方向之前绑定(bind)选择,并取消选择以自由导航到另一 block 重新选择...移动...取消选择...移动。 ..选择。
示例 3:您需要执行示例 2 中的操作,但您必须更换图 block 并记住您的起始位置以填充已删除的图 block 。所以零件改变了位置。这意味着您将获得一组无法被破坏的碎片。他们只能改变位置。
通过按键和键映射以及唯一的 ID 或类以及选择/取消选择,您可以绑定(bind)事物的组合,但您需要确定事件最终结果。
如果您不能在表上使用唯一的 id 或类,您可以使用父级、同级、子级 jQuery 选择器。
下一步: <td>
里面有什么?它是图像还是背景颜色?您可以分配引用图像或颜色的 css 类/id。这样一来,您的辅助选择器就可以用于移动、删除、保留或销毁、附加。
您可以使用指定的类/id 或parent、sibling、child 来获取容器标签的内容。从那里你必须自己回答你正在尝试做什么......最终结果。一个人如何获胜或失败。
关于javascript - 使用键盘按键导航网页(在内容脚本内),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24720160/
我对 JavaScript 上的 onkeypress 事件有疑问。 是否可以仅检测 Cntl 键或 Alt 键?此时,如果同时按下 Cntl 和 m,则 onkeypress 事件可以触发单击。是否
我想知道按键中允许使用什么样的字符。它是否也生成一个符号下划线(_)?我总是得到一个带有 - 字母的按键。 最佳答案 按键使用修改过的 Base64 字母表: -0123456789ABCDEFGHI
我有以下格式的(格式错误的DITA)XML: BLARG BLARG Definition BLARG2 BLARG2 Definition BLARG3 BLARG3 Definition
我有两个单独的对象数组,如果特定键值匹配,我需要将它们合并。分析数据后可能更有意义: 数组 1 let categories = [ { id: 5, slug: 'category-5',
由于我是新手,所以我的低效编码给大家带来了巨大的麻烦,对此我提前表示歉意。 我正在尝试在 HTML5 Canvas 上使用 Javascript 制作一个非常基本的游戏,但我似乎找不到一种简单的方法来
我试图找出将多维数组中的对象 id 属性映射到共享相同 id 的另一个数组中的对象值的最佳方法。 举个例子,我有一个像这样的genre_ids数组: 0: {id: 1, name: 'sci-fi'
我有一个游戏,当按下一个键时,您可以通过将子弹添加到 Controller 类来发射子弹。这是代码来自 KeyPressed(); else if (key == KeyEvent.VK_Q && !
我想比较两个字典的长度以及每个字典中每个键、值对的长度。如果在查找时没有匹配项,我还需要能够打印出来。 我当前的代码似乎传递了长度标准,但在尝试匹配元素时失败: assert_that(len(mod
我正在寻找一种跨平台(Win 和 MacOS)方法来检测 C# 中 OpenGL 应用程序的按键。 以下有效,但仅适用于字母数字字符。 protected override void OnKeyPre
我正在 try catch 按键事件(向上和向下翻页),但根本没有收到任何按键事件。这是相关代码:构造函数: private MainLayout() { imageView = new Im
$(el).bind('blur keypress', function(event){ if(event.type == 'keypress' && event.keyCode != 13) r
我有这段代码: while (SDL_PollEvent(&event)) { if (event.type == SDL_KEYDOWN) { switch(event.key.keys
我正在使用下面的代码: $(document).keypress(function (e) { if (e.which === 68 || e.which === 100) {
我正在用 html 和 javascript 制作游戏。只是为了澄清,这不是重复或任何东西。没有什么可以给我我需要的答案。另外,在解释之前,我想说我对按键监听器没有任何问题,我的游戏知道何时按下按键以
我正在尝试用 Javascript 制作游戏,但目前我已经陷入停滞。我正在尝试检测按键并检查它们是否不断按下以移动 Angular 色。这是我正在使用的代码: var THREE; var keys;
我得到了多维数组。我想从每个子数组中删除/取消设置索引为 1 的值。我的数组 $data。 Array ( [3463] => Array ( [0]
我正在设计一个基于网络的会计软件。例如,每当用户按 N 键时,我想打开“新会计凭证”。并在他/她按下 S 键时打开“设置”。 我看到了一些基于 JavaScript 和 jQuery 的脚本。但它们并
阅读此主题后: Keypress events stopped working outside of "input" elements in Meteor after update to 0.5.2
所以,当我按下按钮 1“1 PLAY/STOP”时,按钮变成绿色,当我再次按下它时它会去除颜色。 如果我按下 button2“2 PLAY/STOP”,同样的事情会发生。 如果两个按钮之一播放而我按下
非常直接的问题。 只想按一个键盘键。像输入一样,使用 pywin auto。我不想在任何应用程序窗口的上下文中按下它。 只是键盘键的原始按键,如 a 或 enter 或退格。 最佳答案 只需使用 #
我是一名优秀的程序员,十分优秀!