如何验证ajax表单

How to validate ajax form?

本文关键字:ajax 表单 验证 何验证      更新时间:2023-09-26

我正在使用jQuery FormBuilder插件在我的应用程序中生成一个表单生成器。

问题是,我还有另外两个输入字段需要与此一起提交。

我的表单结构如下:

<script>
    $(function() {
        $('#my-form-builder').formbuilder({
            'save_url' : 'examplesave',
            'load_url' : 'examplejson',
            'useJson' : true
        });
    });
</script>
<form id="myForm">
    <input type="text" id="fname" />
    <input type="text" id="lname" />
    <div id="my-form-builder"></div>
</form>

我已经编辑了jquery.formbuilder.js文件以附加其他两个输入字段:

// saves the serialized data to the server
            var save = function () {
                    var fname= $('#fname').val();
                    var lname= $('#lname').val();
                    if (opts.save_url) {
                        $.ajax({
                            type: "POST",
                            url: opts.save_url,
                            data: $(ul_obj).serializeFormList({
                                prepend: opts.serialize_prefix
                            }) + "&form_id=" + form_db_id + "&fname=" +fname + "&lname=" +lname,
                            success: function () {}
                        });
                    }
                };

到目前为止,一切都很好。这非常好用。问题是我想在提交之前使用jquery Validate plugin来验证输入字段。现在我可以在(document).ready上使用jQuery Form plugin来验证字段。类似于:

$('#myForm').ajaxForm(
                {
                    type: "POST",
                    url: "examplesave",
                    data: ?????????????????????????????????
                    beforeSubmit : function() {
                        $("#myForm").validate({
                            rules : {
                                fname : {
                                    required : true
                                },
                                lname : {
                                    required : true
                                }
                            },
                            messages : {
                                fname : "Please enter...",
                                lname : "Please enter..."
                            }
                        });
                        return $("#myForm").valid();
                    },
                    success : function() {}
                });

但是我如何获得数据

data: $(ul_obj).serializeFormList({
                                    prepend: opts.serialize_prefix
                                }) + "&form_id=" + form_db_id + "&fname=" +fname + "&lname=" +lname

部分?它只是按原样提交表单&jQuery表单生成器无法将输入序列化在一起。我如何在这里使用序列化插件?我真的陷入了困境。我不太擅长javascript。

有人能指导我吗?如果不清楚,我可以补充更多细节。我绞尽脑汁。还有其他方法吗?请提出建议。

尝试使用serialize()函数

  ...
  data:$("#myForm").serialize();

这将从元素中序列化所有您