jquery:阻止表单提交

发布于 2024-10-12 03:19:49 字数 317 浏览 8 评论 0原文

嘿伙计们, 我有一个可以用向上和向下键影响的表单。

如果没有该代码,它只是一个触发正常操作的正常输入搜索字段。但是我想知道当我使用向上和向下箭头键更改输入字段的值时如何停止默认行为。

看看这个: http://jsfiddle.net/3UHVY/7

我只希望在以下情况下发生警报我使用向上和向下键更改该框的值,否则不应触发任何警报,并且应正常提交表单。但是,如果通过箭头键更改输入值,则应触发警报并且不应提交表单。

知道如何解决这个问题吗?

hey guys,
i have a form that can be influenced with up and down keys.

without that code it's just a normal input-search field that fires a normal action. however i wonder how i can stop the default behaviour when i change the value of the input field with the Up and Down arrow keys.

check out this: http://jsfiddle.net/3UHVY/7

I only want the alert to happen if I change the value of the box with the up and down keys, otherwise no alert should be fired and the form should be submitted normally. However if the input-value is changed via the arrow keys JUST THE ALERT should be fired and the form should not be submitted.

any idea how to solve that?

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

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

发布评论

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

评论(3

独夜无伴 2024-10-19 03:19:49

http://jsfiddle.net/3UHVY/14/

var ok=0;
$(window).keydown(function(e) {

$('.s').focus(); 
switch ( e.keyCode ) {
case 38: // Up
    $('.s').val('Up pressed');
    ok=1;
    break;
case 40: // Down
    $('.s').val('Down pressed'); 
    ok=1;
    break;
case 13: // Enter
    if(ok)
    alert($('.s').val());
    break;
default:
ok=0;
break;
}
});

http://jsfiddle.net/3UHVY/14/

var ok=0;
$(window).keydown(function(e) {

$('.s').focus(); 
switch ( e.keyCode ) {
case 38: // Up
    $('.s').val('Up pressed');
    ok=1;
    break;
case 40: // Down
    $('.s').val('Down pressed'); 
    ok=1;
    break;
case 13: // Enter
    if(ok)
    alert($('.s').val());
    break;
default:
ok=0;
break;
}
});
雨后彩虹 2024-10-19 03:19:49

我不完全确定你想要发生什么,但是以下 jQuery:

$('.s').keydown(
    function(e) {
        var keyPreesed = e.keyCode;

        if (keyPreesed == 38) {
            var msg = "Up was pressed.";
            $(this).val(msg);
            alert(msg);
        }
        else if (keyPreesed == 40) {
            var msg = "Down was pressed.";
            $(this).val(msg);
            alert(msg);
        }
        else {
            // meither 'up' nor 'down' was pressed, do whatever

            // $(this).closest('form').submit(); // <- this (uncommented) will trigger the form's submission.
        }
    });

JS Fiddle demo

问题是我不确定您想要在哪里触发提交,尽管我假设您希望在既没有按下向上也没有按下时进行提交,因此它位于 else 中 声明)。

I'm not entirely sure what you want to happen, but the following jQuery:

$('.s').keydown(
    function(e) {
        var keyPreesed = e.keyCode;

        if (keyPreesed == 38) {
            var msg = "Up was pressed.";
            $(this).val(msg);
            alert(msg);
        }
        else if (keyPreesed == 40) {
            var msg = "Down was pressed.";
            $(this).val(msg);
            alert(msg);
        }
        else {
            // meither 'up' nor 'down' was pressed, do whatever

            // $(this).closest('form').submit(); // <- this (uncommented) will trigger the form's submission.
        }
    });

JS Fiddle demo

The problem is that I'm not sure where you want to trigger the submit, though I've assumed you want submission to occur if neither up nor down is pressed, hence it's in the else statement).

绅士风度i 2024-10-19 03:19:49
function FormHandler() {
  var changedByUpDown = false;
  this.onKeyDown = function(event) {
    if (event.keyCode == 38 || event.keyCode == 40) {
      changedByUpDown = true;
    }
  };
  this.onSubmit = function(event) {
    if (changedByUpDown) {
      alert('Changed by up/down');
      return false;
    }
    return true;
  }
}

var fh = new FormHandler();
$('#search_form').submit(fh.onSubmit);
$('#searchsubmit').keydown(fh.onKeyDown);

几点说明:

  • 你可以返回 false (以停止
    事件)按上/下键后,
    停止默认的向上/向下行为
    (自动完成建议)
  • 您可以始终将changedByUpDown 设置为 false
    当用户输入不同的内容时
    比向上/向下,所以形式是“新鲜的”,
  • 你当然可以添加
    按下时提交表单的代码
    输入 (13)
function FormHandler() {
  var changedByUpDown = false;
  this.onKeyDown = function(event) {
    if (event.keyCode == 38 || event.keyCode == 40) {
      changedByUpDown = true;
    }
  };
  this.onSubmit = function(event) {
    if (changedByUpDown) {
      alert('Changed by up/down');
      return false;
    }
    return true;
  }
}

var fh = new FormHandler();
$('#search_form').submit(fh.onSubmit);
$('#searchsubmit').keydown(fh.onKeyDown);

Few notes:

  • you can return false (to stop the
    event) after pressing up/down, to
    stop default up/down behavior
    (autocomplete suggestions)
  • you can set changedByUpDown to false always
    when user inputs something different
    than up/down, so the form is "fresh"
  • you can of course add
    code to submit the form when pressing
    enter (13)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文