【问题标题】:jQuery Submit Refreshing PagejQuery提交刷新页面
【发布时间】:2011-02-24 01:45:50
【问题描述】:

以下代码旨在执行纯粹的 ajax POST 请求,而不是似乎通过 ajax 执行 POST,然后浏览器导航到响应。

HTML...

<div id="bin">
    <form class="add" method="post" action="/bin/add/">
        <p>I'm interested! Save for later.</p>
        <input type="hidden" name="product_id" value="23423">
        <input type="submit" value="Save">
    </form> 
    <form style="display:none;" class="remove" method="post" action="/bin/remove/">
        <p>I changed my mind--I'm not interested.</p>
        <input type="hidden" name="product_id" value="23423">
        <input type="submit" value="Unsave">
    </form>
</div>

jQuery...

$('#bin form').submit(function() {
                $.post($(this).attr('action'),{
                    success: function(data) { $(this).hide().siblings('form').show() },
                    data: $(this).serialize()

                });
                return false;
            })

据我了解,return false; 行应该意味着无论如何,任何对提交函数的调用或单击“提交”按钮或按回车都意味着我的函数将执行并且浏览器不会导航到/bin/add/bin/remove。但是由于某种原因,浏览器 正在更改页面。

知道我在这里做错了什么吗?谢谢。

【问题讨论】:

    标签: javascript jquery html ajax http-post


    【解决方案1】:

    可能是您的 JavaScript 失败,因此正在执行默认行为。

    尝试在 Firebug 等工具中检查 XHR。

    另外,您可以尝试event.preventDefault()(其中事件回调的第一个参数是event)。

    【讨论】:

    • 哎呀。看起来你是对的,我的 javascript 中有一个错误,因此它正在死亡并允许默认操作(也就是离开页面)发生。我从来没有在萤火虫中看到过,因为,当然,页面改变了。通过使用event.preventDefault(),我现在能够检查萤火虫中的错误。谢谢!
    【解决方案2】:

    我敢打赌是因为$(this),试试这种方式....

    $('#bin form').submit(function() {
        var $this = $(this);
        $.post($this.attr('action'), {
            success: function(data) {
                $this.hide().siblings('form').show()
            },
            data: $this.serialize()
    
        });
        return false;
    });
    

    demo 没有错误

    demo 出现错误

    【讨论】:

    • 我太慢了 :) 我需要学会每隔一段时间点击编辑窗口。
    【解决方案3】:

    使用event.preventDefault() 来阻止事件的默认操作。一个好处是您可以将它放在 Ajax 请求之前,这样如果它失败,您仍然会阻止表单提交。

    您的代码失败了,因为成功回调中 this 的值是全局 window 对象。你试图隐藏它失败了。您可能希望this 引用该表单,如下所示:

    $('#bin form').submit(function(ev) {
        var _this = this;
        ev.preventDefault();
        $.post($(this).attr('action'), {
            success: function() {     
               $(_this).hide().siblings('form').show();
            },
            data: $(this).serialize()
        });
    })
    

    查看working example

    【讨论】:

    • $(this).attr('action') 部分... :)
    【解决方案4】:

    $(...).submit(...) 是否在 $(document).ready(function(){ code here }); 内?

    应该是这样的:

    $(document).ready(function() {
        $('#bin form').submit(function() {
                $.post($(this).attr('action'), {
                    success: function(data) { $(this).hide().siblings('form').show(); },
                    data: $(this).serialize()
                });
                return false;
            });
    });
    

    【讨论】:

    • 抱歉,我应该在 $(document).ready 函数中指定它
    猜你喜欢
    • 2020-06-29
    • 2012-05-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-08-26
    • 2011-12-10
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多