gpt4 book ai didi

javascript - 当焦点从一个文本字段更改为另一个文本字段时,如何防止屏幕键盘消失

转载 作者:太空宇宙 更新时间:2023-11-03 10:47:34 25 4
gpt4 key购买 nike

我有一个 HTML5 应用程序,它使用一些 input type="text"字段来输入文本。我正在捕捉击键事件,以便将某些字段链接在一起。

我在任何移动设备上测试时遇到问题。最初我在使用 Safari 或 Chrome 的 iPad 上尝试过。然而,后来我也在运行最新版本的 Mobile Firefox 的 android 设备上进行了尝试,并遇到了同样的问题。

问题在于,一旦输入元素发生变化,屏幕键盘就会消失。我尝试过以几种不同的方式执行此操作,但它似乎总是产生相同的效果——只要我将 focus() 放在不同的文本输入上,键盘就会消失。这代表了一个严重的流动障碍,因为它需要一个额外的 Action 来正确地重新选择一个已经被选中并且应该有焦点并获得键盘输入的文本字段。在手机等小型设备上,情况更糟,因为所有这些都伴随着缩放和平移,因为键盘的移除和重新显示会导致页面重新呈现。这与编辑文本文档时键盘停止工作并且每次按回车键都需要重新插入时所发生的情况类似 - 这显然是一个严重问题。

以下最少的代码重现了该问题:

<!doctype html>
<html lang="en">
<head>
<style type="text/css">
:focus { color: red; }
</style>

<script type="text/javascript">
function init() {
var tf1 = document.getElementById('tf1')
var tf2 = document.getElementById('tf2')
tf1.focus()
tf1.onkeydown = function(evt) {
if (evt.which == KeyEvent.DOM_VK_RETURN
|| evt.which == KeyEvent.DOM_VK_Q
|| evt.which == KeyEvent.DOM_VK_ENTER) {
tf2.focus()
if (evt.stopPropogation) evt.stopPropogation()
if (evt.preventDefault) evt.preventDefault()
return false
}
}
}
</script>
<body onload="init()">
<input type='text' id='tf1' value='field1' />
<input type='text' id='tf2' value='field2' />
</body>
</html>

我注意到的第一件事是,虽然初始 focus() 有效(元素变为红色),但屏幕键盘没有出现。虽然这很麻烦,但点击以开始点击文本字段并不是什么大不了的事。然而,只要我按下任何触发键(我在其中输入了一个普通字符以确认它是什么无关紧要),键盘突然消失了。这对我来说没有任何意义,不仅文本元素仍然聚焦,这需要屏幕键盘,而且是键盘事件改变了焦点,这表明可能仍然需要键盘 - 它是不像我这样做是因为延迟或其他原因。

我已经尝试过 onkeydown、onkeyup 和 onkeypress - 都表现出相同的行为。

如何防止屏幕键盘消失?我已经浪费了很多时间试图让这一关键功能发挥作用,但它仍然没有!我需要包含某种元标记吗?或者只是所有移动设备都存在的普遍存在的跨平台错误

最佳答案

尝试使用 click() 方法代替或在 tf1.focus() 之后使用;

像这样:

tf1.click();

这可能导致很少或没有软件键盘隐藏。

关于javascript - 当焦点从一个文本字段更改为另一个文本字段时,如何防止屏幕键盘消失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20294585/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com