选择页面中的所有表单并序列化其输入值

sky*_*ar7 4 jquery jquery-selectors jqueryform

您好我想尝试选择页面中的所有表单,然后序列化他们的输入值,我使用以下代码:

function serializeAllFormData() {
                        var serializedData;
                        $("#form").each(
                                function() {
                                    serializedData = serializedData
                                            + $(this).serialize();
                                });
                        return serializedData;
                    }
Run Code Online (Sandbox Code Playgroud)

但是当我检查serializedData时它是未定义的,我做错了什么?

Chr*_*son 11

您正在选择表单,就好像它们是ID一样#form(#只有在选择ID时才使用哈希符号).请尝试使用form.

$("form").each(function() {
   serializedData = serializedData + $(this).serialize();
});
Run Code Online (Sandbox Code Playgroud)

更新

根据文档,每个函数可以采用第一个参数(indexInArray).所以你可以这样做:

var forms = $("form");
forms.each(function(i) {
   serializedData = serializedData + $(this).serialize();

   // i will start a 0, therefor forms.length - 1 in the if-statement
   if (i === forms.length - 1) {
      // Do something on the last element
   }
});
Run Code Online (Sandbox Code Playgroud)

我将表单缓存在变量中,这样我们就不必在每次循环运行时都通过DOM.