4

我将 jQuery 与表单插件结合使用,我想在提交之前拦截表单数据并进行更改。

表单插件有一个名为 beforeSubmit 的属性,它应该执行此操作,但我似乎无法让我指定的函数运行。

这是表单的标记(省略了一些样式细节):

<form id="form1">
    <fieldset id="login">
        <legend>Please Log In</legend>
        <label for="txtLogin">Login</label>
        <input id="txtLogin" type="text" />
        <label for="txtPassword">Password</label>
        <input id="txtPassword" type="password" />
        <button type="submit" id="btnLogin">Log In</button>
    </fieldset>
</form>

这是我到目前为止的javascript:

$(document).ready(function() {
    var options = {
        method: 'post',
        url: 'Login.aspx',
        beforeSubmit: function(formData, form, options) {
            $.each(formData, function() { log.info(this.value); });
            return true;
        }
    };
    $('form#form1').ajaxForm(options);
});

(log.info() 来自我正在使用的Blackbird调试器库)

当我单击提交按钮时,而不是我指定的 POST 动词,它使用 GET 代替,并且我的 beforeSubmit 函数没有记录任何内容。似乎 ajaxForm 插件根本没有应用于表单,但我不明白为什么。有人可以帮忙吗?

4

2 回答 2

3

我通过 firebug 运行了以下代码,它似乎像宣传的那样工作,但是 beforeSubmit 回调中的 formData 变量为空,因为您没有在文本框上设置 name 属性。

<script type="text/javascript">
  $(document).ready(function() {
    var options = {
      beforeSubmit: showData
    };
    $('form#form1').ajaxForm(options);
  });
  function showData(formData, form, options) {
    //var formData = [ { name: 'username', value: 'jresig' }, { name: 'password', value: 'secret' } ];
    $.each(formData, function(i, obj) { log.info(obj.name + " | " + obj.value); });
    return true;
  }
</script>

<form id="form1" action="Login.aspx" method="post">
<fieldset id="login">
    <legend>Please Log In</legend>
    <label for="txtLogin">Login</label>
    <input id="txtLogin" type="text" name="User" />
    <label for="txtPassword">Password</label>
    <input id="txtPassword" type="password" name="Pass" />
    <button type="submit" id="btnLogin">Log In</button>
</fieldset>
</form>
于 2008-12-05T19:51:01.317 回答
1

对于初学者,根据这个 API,你的 options 对象应该使用typeand not method,或者只是在 HTML 的表单中指定方法属性。

(现在我将添加一些小的文体注释;如果您愿意,可以在此处停止阅读):

  1. 您可以替换$(document).ready(function...$(function....
  2. $.each(formData, function...看起来更自然$(formData).each(function...
于 2008-12-05T19:58:30.520 回答