html PhoneGap Android:数字软键盘有下一个而不是转到按钮

发布于 2025-01-04 06:23:50 字数 336 浏览 1 评论 0原文

这让我发疯,我在任何地方都找不到答案。

我的phonegap 应用程序中有表格。如果输入type=“text”,则弹出文本键盘,并在角落显示“go”。当您单击“开始”时,它会提交表单。这一切都按我的预期进行。但如果我使用输入类型=“数字”,则会弹出数字键盘,并在角落中显示“下一个”。当您单击“下一步”时,如果按钮标签之前还有另一个输入框,则会转到该输入。没关系。 。 。不理想,但有道理。但如果它是页面上的最后一个输入字段,则单击“下一步”不会执行任何操作。它不会将焦点放在按钮上(即使使用 tabindex),也不会提交表单(理想情况)。

我正在使用phonegap 1.3.0 和jquery 1.7(如果有帮助的话)。

This is driving me crazy and I can't find the answer anywhere.

I have forms in my phonegap app. If the input type="text", the text keyboard pops up and "go" is displayed in the corner. When you click go, it submits the form. That all works as I would expect. But if I use input type="number", the number keyboard pops up and "next" is displayed in the corner. When you click next, if there is another input box before the button tag, it goes to that input. That's okay. . . not ideal, but makes sense. But if it is the last input field on the page, click "next" does nothing. It doesn't put focus on the button (even with tabindex) and it doesn't submit the form (ideal).

I'm using phonegap 1.3.0 and jquery 1.7 if any of that helps.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

小瓶盖 2025-01-11 06:23:50

您可以通过在 JQuery 中使用以下绑定来检测下一次键盘按下:

$('input').on('keydown', function(e){
    if(e.which === 9) {
        //your code here
    }
});

“下一个”按钮模拟键盘上的 Tab 键按下事件,即键代码 9。不幸的是,keypress 和 keyup 事件不会检测下一个键事件,因此你需要将它绑定在 keydown 上。

希望有帮助!

You can detect the next keyboard press by using the following bind in JQuery:

$('input').on('keydown', function(e){
    if(e.which === 9) {
        //your code here
    }
});

The 'next' button emulates the tab keypress event on a keyboard, which is key code 9. Unfortunately, keypress and keyup events do not detect the next key event, so you need to bind it on keydown.

Hope that helps!

翻了热茶 2025-01-11 06:23:50

好吧,现在我确实有了一些看起来像答案并且嘎嘎叫起来像答案的东西。

这是一次可怕的黑客攻击,目前我正在经历一些副作用,但无论如何这对人类来说是一个小小的飞跃。

将不可见的文本输入添加到表单中,一旦获得焦点就会自动提交表单。由于它只能从用户按“下一步”或从最后一个数字字段按 Tab 键接收焦点,因此用户序列中应该有相当可靠的逻辑。

<input type='text' style="opacity:0;" onfocus="javascript:$('#thisForm').submit();">

副作用是:

  • 隐藏的表单字段将短暂可见。您可以通过以下方式避免这种情况
    使用 onfocus 处理程序也可以重新关注数字字段
    刚刚离开。或者您可以将输入的宽度设置为 0。后者最适合我。
  • 如果你像我一样使用 jQueryMobile,你就会给自己带来可怕的页面转换丑陋,所以如果你的表单位于对话框中并且提交表单会关闭对话框,请务必设置对话框转换(当它从上一个屏幕)更改为“无”。

Okay, now I do have something that looks like an answer and quacks like an answer.

It's a horrible hack, and I am experiencing some side-effects at this point, but it's a small leap for mankind anyway.

Add an invisible text input to your form, which automatically submits the form as soon as it receives focus. Since it can only receive focus from the user pressing 'Next' or tabbing from the last number field, there should be a pretty solid logic in the user sequence.

<input type='text' style="opacity:0;" onfocus="javascript:$('#thisForm').submit();">

The side effects are:

  • the hidden form field will briefly be visible. You can avoid this by
    using the onfocus handler to also re-focus on the number field that
    was just left. Or you can set the width of the input to 0. The latter works best for me.
  • if you're using jQueryMobile like me, you're inviting horrible page transition ugliness on yourself, so if your form is in a dialog and submitting the form closes the dialog, be sure to set the dialog transition (when it is being opened from a previous screen) to 'none'.
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文