javascript - 表单数据未发布到 $.ajax url

标签 javascript php jquery html ajax

从自定义 CSS 模式发布表单时,数据将发布到当前 URL,而不是设置的 URL。

$("form.delete_photo_form").submit(function(e) 
{
    e.preventDefault();

    $(".delete_photo_message").text("");


    $.ajax({
        url: 'assets/php/delete_photo.php',
        type: 'post',
        data:  $(this).serialize(),
        success: function(data, status) 
        {
            if (data == 1)
            {
                $(".delete_photo_message").text("Unable to delete photo");
            }                           
            else if (data == 2)
            {
                $(".delete_photo_message").text("Photo deleted");
                // checkGroup();
            }                           
            else
            {
                $(".delete_photo_message").text(data);  
            }
      },
      error: function(xhr, desc, err) {
        console.log(xhr);
        console.log("Details: " + desc + "\nError:" + err);
      }
    }); 

此表单是从另一个模式打开的模式中发布的。

原始模态:

<div id="photo_buttons">

<a id="edit_photo_modal" class="button" href="#edit_photos_modal">

    Edit Photos

</a>
<div id="edit_photos_modal" class="modal_photos">
    <div>
        <a id="close_edit_photo" title="Close" href="#close"></a>


                                Edit Photos:


        <br></br>
        <br></br>
        <div class="edit_photos_div">
            <div class="photo_line">
                <img src="images/thumbnails/group/11/bb0878d2390cdcfb.jpg"></img>
                <br></br>
                <a id="edit_photo" class="open_modal" href="#modal_edit_photo_39">

                    Edit

                </a>


                                      /  


                <a id="delete_photo" href="#modal_delete_photo_39">

                    Delete

                </a>
                <br></br>
                <br></br>
            </div>                
        </div>
        <a id="finish_edit" class="button" title="Finish" href="#finish">

            Finish

        </a>
    </div>
</div>
<script src="assets/js/edit_photo.js"></script>

第二个模态(这是调用 ajax post 的地方):

    <div id="edit_modals">
    <div id="modal_edit_photo_39" class="modal">
        <div>
            <a id="close_39" title="Close" href="#close">

                Close

            </a>
            <form id="edit_photo_form_39" class="edit_photo_form" method="post" action="">
                <h4>

                    Edit Photo

                </h4>
                <br></br>
                <h3 id="edit_photo_message" class="edit_photo_message"></h3>



                                            Title:

                <input id="edit_title" type="text" value="Test photo" name="edit_title"></input>



                                            Description:

                <textarea id="edit_desc" name="edit_desc" rows="3">

                    Test for resize

                </textarea>
                <br></br>
                <input type="hidden" value="11" name="group_id"></input>
                <input type="hidden" value="39" name="photo_id"></input>
                <input id="edit_photo_yes_39" class="edit_yes" type="submit" title="Edit" value="Edit" name="edit_yes"></input>
                <a id="cancel_edit" class="button" title="Cancel" href="#cancel_edit">

                    Cancel

                </a>
            </form>
        </div>
    </div>
    <div id="modal_delete_photo_39" class="modal">
        <div>
            <a id="close_39" title="Close" href="#close">

                Close

            </a>
            <form id="delete_photo_form_39" class="delete_photo_form" method="post" action="">
                <h4>

                    Are you sure you want to delete this photo?

                </h4>
                <br></br>
                <h3 id="delete_photo_message" class="delete_photo_message"></h3>
                <input type="hidden" value="11" name="group_id"></input>
                <input type="hidden" value="39" name="photo_id"></input>
                <input id="delete_photo_yes_39" class="delete_yes" type="submit" title="Yes" value="Yes" name="delete_yes"></input>
                <a id="del_no" class="button" title="No" href="#no">

                    No

                </a>
            </form>
        </div>
    </div>        
</div>

如果有人有任何想法,请告诉我。

旁注:

如果单独调用第二个模态而不是从第一个模态调用,则表单提交函数可以正常工作。

最佳答案

您有可能在 $("form.delete_photo_form") 之后动态创建表单。选择器已运行,或者模态脚本可能会移动表单在 DOM 中的位置(即,某些模态脚本将模态内容移动到 <body> 标记的最末尾)。

无论哪种情况,这都会导致您的提交逻辑无法运行。尝试替换:

$("form.delete_photo_form").submit(<handler>);

...与:

$(document).on("submit", "form.delete_photo_form", <handler>);

如果您不熟悉上述语法,这是 jQuery 的语法 event delegation ,它允许您将事件处理程序绑定(bind)到永久的对象(例如 document 对象),然后如果事件满足特定条件,则有选择地运行处理程序逻辑(在这种情况下,事件必须是“submit”类型,并且必须源自与 "form.delete_photo_form" 选择器匹配的元素)。这样做的好处是,即使尚未创建相关 DOM 节点,您也可以设置事件监听器。

关于javascript - 表单数据未发布到 $.ajax url,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31525229/

相关文章:

javascript - 如何针对不同时区测试浏览器时区相关应用程序?

javascript - 如何在加载时屏蔽输入(单击之前)

php - SPARQL 查询以获取节点的所有父节点

jquery - jquery如何动态改变文本区域的高度?

Jquery从右向左滑动

javascript - 在开始一个会自行循环的函数之前延迟 6 秒,这个函数很小,不起作用,为什么?

javascript - 加载 web View 中的 NSURLSession/NSURLConnection HTTP 加载失败(kCFStreamErrorDomainSSL,-9814)?

javascript - Vue JS 中 axios 调用后 focus() 不起作用

PHP MySQL查询插入一致错误

javascript - 带有 AngularJS 的 jQuery slider