我很难在javascript / jQuery中将退格键捕获为键盘事件。在Firefox,Safari,Opera,Chrome和iPhone / iPad上,我在文本输入框上捕获了一个keyup事件,如下所示:
$(id_input).keyup(function(event) {
that.GetHints($(this).val().trim(), event, fieldName);
});
此事件捕获用户击键,然后将它们发送到函数以发出ajax查找调用。
当用户希望对他/她已输入的角色进行退格时,我的问题就来了。在除了我的Droid手机之外我可以访问的所有浏览器中,当我按退格键时,此keyup事件捕获$(this).val()。trim()返回的值并将其发送到函数进程GetHints。但是,在Droid上,在用户对$(this)中的每个字符进行退格操作之前,此keyup和等效的keydown事件都不会触发。
所以,例如,如果我输入“cu”然后退回“u”,在输入字段中仅留下“c”,在除Droid之外的所有浏览器中,keyup事件将触发并调用函数GetHints("c", event, fieldName)
。在Droid上,keyup事件永远不会发生。
我错过了什么?如何/为什么我的Droid上的软键盘或硬键盘上的退格键不能按预期运行?我该如何解决这个问题?
答案 0 :(得分:2)
您可以轮询文本中的更改(使用setInterval
)。这可能更可靠。例如,如果用户右击,则不会触发密钥 - >切。单独轮询会降低响应速度,但你可以将它与keyup相结合,以保持它的活泼。轮询会使处理器更加沉重。
尝试以下几点:
var oldText = '';
var timer = setInterval(function(){
var text = $(id_input).val().trim();
if(text != oldText){
oldText = text;
that.GetHints(text, fieldName);
}
}, 500);
根据需要调整间隔持续时间。
我不确定that.GetHints
对event
做了什么,但很明显,你无法通过使用轮询方法传递它(因为没有实际的事件被触发)。这是一个问题吗?
如果您愿意,可以使用clearInterval(timer);
停止轮询。
您可以保持现有的键盘功能(以提高响应速度)。或者,您可能希望仅轮询以避免that.GetHints
被调用过多(例如,如果某人真的很快地输入了某些内容)。