- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想要一个 PIN 输入表单,其中每个字符都输入到单独的 html 输入中。
我正在 try catch JavaScript 中的 keyup 事件,以便我可以将焦点更改为下一个输入元素,从而使用户无需通过单击鼠标或选项卡自行更改它。
除非用户打字速度非常快,否则它会起作用。例如,如果用户非常快地键入字符“1”和“2”,我发现第一个输入现在正确地具有字符“1”,而第二个输入仍然为空,并且焦点已移至第三个输入输入。
为什么?代码如下:
$(document).ready(function () {
$('.pinchar').keyup(function (e) {
if (
(e.which == 8) //backspace
|| (e.which == 46) // del
|| (e.which == 9) // tab
|| (e.which == 13) // return
|| (e.which == 27) // esc
|| (e.which == 37) // arrow
|| (e.which == 38) // arrow
|| (e.which == 39) // arrow
|| (e.which == 40) // arrow
|| (e.which == 27) // esc
|| (e.which == 20) // CAPS LOCK
|| (e.which == 17) // Ctrl
|| (e.which == 18) // Alt
|| (e.which == 16)) { //shift
return false;
} else {
$(this).parent().next().find('.pinchar').focus();
}
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table class="enterPINTable">
<tr>
<td>
<input name="txtPIN1" id="txtPIN1" class="pinchar" size="1">
</td>
<td>
<input name="txtPIN2" id="txtPIN2" class="pinchar" size="1">
</td>
<td>
<input name="txtPIN3" id="txtPIN3" class="pinchar" size="1">
</td>
<td>
<input name="txtPIN4" id="txtPIN4" class="pinchar" size="1">
</td>
</tr>
</table>
最佳答案
当您按下一个键,然后在释放它之前按下另一个键时,
keyup
将失败。事件的顺序为 keydown 1
、keydown 2
、keyup 1
、keydown 2
。但是,由于字符是在 keydown
(和 keypress
)之后生成的,因此在第一个 keyup< 之前的
在这种情况下发生事件。input
中已经有两个字符
尝试使用 input
事件:
$('.pinchar').on('input', function (e) {
// ... etc.
任何更改都会立即触发。
但要正确处理其他键,您还需要捕获 keydown
事件(对于箭头键和退格键)。
我建议使用这段代码:
$(document).ready(function () {
var $inputs = $(".enterPINTable .pinchar");
function step(inp, dir, clr) {
if (clr) $(inp).val("");
var buffer = $(inp).val(); // get excess characters
// spread characters in next boxes to ensure max 1 char
var curr = $inputs.index(inp);
for (var i = curr, j = 0; j < buffer.length && i < $inputs.length; i++, j++) {
$inputs.eq(i).val(buffer[j]);
}
if (dir < 0) curr-= curr > 0;
else curr = Math.min(curr + (j||dir), $inputs.length-1);
var $next = $inputs.eq(curr);
$next.focus();
setTimeout(function () {
$next.select();
}, 0);
return false;
}
$inputs.on("focus", function () {
$(this).select(); // always select the "whole" (1 char) text
}).on("mouseup", function () { // Attempt to unselect?
setTimeout(function () { // Keep character selected....
$(this).select();
}.bind(this));
}).on("keydown", function (e) {
if (e.key == "ArrowLeft" || e.key == "ArrowUp") return step(this, -1);
if (e.key == "ArrowRight" || e.key == "ArrowDown") return step(this, 1);
if (e.key == "Backspace") return step(this, -1, 1);
}).on("input", function (e) {
step(this, 0);
}).eq(0).focus();
});
.pinchar { width: 1em; text-align: center }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table class="enterPINTable">
<tr>
<td>
<input name="txtPIN1" id="txtPIN1" class="pinchar">
</td>
<td>
<input name="txtPIN2" id="txtPIN2" class="pinchar">
</td>
<td>
<input name="txtPIN3" id="txtPIN3" class="pinchar">
</td>
<td>
<input name="txtPIN4" id="txtPIN4" class="pinchar">
</td>
</tr>
</table>
上面的代码旨在始终选择当前字符,这样如果您键入另一个字符,它就会替换当前字符。如果您成功删除选择(并不容易)并尝试添加第二个字符,它将出现在下一个框中。从剪贴板粘贴一系列字符也会导致每个输入框传播一个字符。
左
、右
、tab
、shift
+tab
、退格键
和删除
键按预期工作。
使用 CSS 调整输入大小并使文本居中,似乎可以提供更好的结果。
关于javascript - keyup 事件处理程序更改焦点不适用于快速打字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37330654/
如何使用打字模块来创建可以是某些字符串的类型? 例如。假设我需要一个类型 CondOperator ,可以是以下任何字符串: ['=', '>', '=', '', '!='] 我希望 CondOpe
我目前正在从事一个处理语言学习(即德语、中文等...)的项目,其中有一个功能我们遇到了问题 - 简而言之,我们正在尝试显示“幽灵” "文本(非常淡的灰色)并允许用户键入覆盖此文本。 该项目将有数千个不
typing 模块提供了一些方便的功能,以实现更好的可读性和对键入代码正确性的信心。 最好的功能之一是您可以编写如下内容来描述具有指定元素类型的输入字典。 def myFun(inputDict:Di
我想创建一个 Array 类型,它应该是可订阅 并且是 typing.List 和 numpy 的联合体.ndarray 类型。我知道 numpy 没有 stub ,但是 those numpy st
我想写一个groupBy功能,到目前为止,类型系统对我的工作不太满意。 export function group( data: T[], groupBy: keyof T ): {
我正在努力解决打字问题并提出以下问题 您在项目的 node_modules 根文件夹下找到的 typings 文件夹是什么。这是 tsc 查找 .d.ts 文件的默认位置吗?我如何在源文件中使用它们。
在打字时使用 typing.Any 和 object 有什么区别吗?例如: def get_item(L: list, i: int) -> typing.Any: return L[i] 相
我刚开始使用 TypeScript,所以请记住。我正在尝试在 React/TS 中实现一个简单的文件上传。一般来说,我认为我不明白如何初始化对象,比如在 useState 中,并正确处理可能性。例如,
我想这是python 3.7(不确定)附带的,不仅可以将变量名传递给函数,还可以传递变量的类型。我想知道的是是否有可能传递特定类的类型。 你可以通过同样的方式: def foo_func(i: int
有没有办法在 TypeScript 类中拥有动态对象属性,并为 TypeScript 添加动态类型? 我见过类似的问题,但没有一个像这样的完整示例 - interface IHasObjectName
我正在尝试将类型添加到一些数字 Racket 代码中,希望能使其更快,但我在下面的代码中遇到了 for/list 宏扩展的问题。 (: index-member ((Listof Any) (List
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 提供事实和引用来回答它. 2年前关闭。 Improve this
我在 Scala 中有一个打字问题的小问题。在 Haskell 中,我可以这样做: add :: (Num a) => (a,a) -> (a,a) -> (a,a) 这样,我就可以扔进add任何支持
我想实现这个。 当文本表单字段处于非事件状态时,其背景和填充颜色将为灰色。但是当我打字或它处于事件模式时,它的背景颜色将为白色。 如何实现这种行为? 最佳答案 试试这个: class CustomTe
我想实现这个。 当文本表单字段处于非事件状态时,其背景和填充颜色将为灰色。但是当我打字或它处于事件模式时,它的背景颜色将为白色。 如何实现这种行为? 最佳答案 试试这个: class CustomTe
这可以模拟击键: import pyautogui pyautogui.typewrite('hello world!', interval=0.1) 除了: 它写的是 hello world§(使用
我正在寻找 python 中的东西因为它是动态类型而更容易编程的例子? 我想将它与 Haskell 类型系统进行比较,因为它的静态类型不像 c# 或 java 那样妨碍。我可以像在 python 中一
当运行 typings 命令时,我总是得到错误: AppData\Roaming\npm\node_modules\typings\node_modules\strip-bom\index.js:2
我正在学习 Ruby,我遇到了一个关于打字的主要概念问题。请允许我详细说明为什么我不理解范式。 假设我像您在 Ruby 中一样为简洁的代码进行方法链接。我必须准确地知道链中每个方法调用的返回类型是什么
只是关于打字的快速问题。 如果我输入 ghci :t [("a",3)]我回来了[("a",3)] :: Num t => [([Char], t)] 在文件中,我将类型定义为: type list
我是一名优秀的程序员,十分优秀!