表格标签过早关闭

Tia*_*nRB 2 javascript php ajax jquery asynchronous

据我所知,这意味着html代码无效,通常是因为嵌套不正确.

通过使用jQuery.ajax()调用的php函数回显,在按下按钮上生成此表单:

<?php

echo '
<div class="row survey-container text-center">
    <form id="surveyForm" action="processSurvey.php" method="post">

        <h3>Alimentos</h3>
        <h4>Sabor</h4>
        <div class="form-group">';
            for ($i = 0; $i <= 10; $i++) {  // Imprime lista de sabor
                echo '
                    <label class="radio-inline">
                        <input type="radio" name="sabor" id="saborRadio'. $i .'" value="'. $i .'">'. $i.'
                    </label>
                ';
            }
            echo '
        </div>
        <div class="form-group">
            <button class="btn btn-default surveyForm-btn" type="submit">Enviar</button>
        </div>

    </form>
</div>
';
?>
Run Code Online (Sandbox Code Playgroud)

所有代码都按预期运行但只有一行:

[...] 
        <form id="surveyForm" action="processSurvey.php" method="post"></form>
[...]
Run Code Online (Sandbox Code Playgroud)

表单一打开就会自动关闭.我打破了一些规则吗?似乎无法找到问题.我不认为问题出在js上,但我会把它包括在内

        $('body').on('submit', '#surveyForm', function(e){
        console.log("Clicked on #surveyForm ");
        var data = $(this).serialize();
        console.log( data );
        $.ajax({
            method: "POST",
            url: "processSurvey.php", 
            data: data, 
            success: function(result){
                console.log("Ajax call to processSurvey success");
                $("#surveyForm").clearForm();
                console.log(result);
                console.log( data );

            } 
        });
        return false;
    });
Run Code Online (Sandbox Code Playgroud)

控制台日志表明一切都很好,但没有数据被发送(空数组),这使得考虑到表单过早地关闭自己.

编辑:我想我知道问题是什么,表格是在表格内创建的,这是无效的HTML(对吗?)我会在修复时发布更新.我应该标记为已回答吗?

epa*_*llo 5

您正在序列化按钮,而不是表单.

var data = $(this).closest("form").serialize();
Run Code Online (Sandbox Code Playgroud)