两次POST请求而不是一次

4

我有一个对象的编辑页面。因为我将数据分成了两个选项卡,所以我使用了jquery-ui。在第一个选项卡(#core_data)中,我加载了对象的主要数据。表单通过Ajax提交:

<form method="post" class="object_form" id="event-core-form" action="{% url edit_event_data event.id %}" enctype="multipart/form-data">
    {{ form.as_p }}
    <p>
        <input class="object-submit" id="event-data-save" type="submit" value="Save data">
    </p>
</form>

js:

$("#event-data-save").livequery("click", function() {
    $("#event-core-form").ajaxSubmit({
        "success": function(data) {
            data = JSON.parse(data)
            $("#core-data").html(data["form"]);               
        }
    });
    return false;
})

当一个函数被调用时,我的调试显示它立即被调用了两次:

def edit_event_data(request, event_id,):
    template_name="management/core_event.html" 
    event = get_object_or_404(Event, pk=event_id)
    form = EventForm(instance=event, data=request.POST)

    if form.is_valid():
        form.save()
        form = EventForm(instance=event)

    form_html = render_to_string(template_name, RequestContext(request, {
        "event" : event,
        "form" : form,
    }))

    result = simplejson.dumps({
        "form": form_html,
        "message": "Data saved."
    }, cls=LazyEncoder)

    return HttpResponse(result, mimetype='application/javascript')

此外,成功提交后再次点击保存会给我一个未经处理的原始表单:/ 这是我正在使用的表单。我认为这可能是我的问题所在:
class EventForm(forms.ModelForm):   
    def __init__(self, *args, **kwargs):
        logging.debug("form - init")
        super(EventForm, self).__init__(*args, **kwargs)

    (...)

    def save(self, *args, **kwargs):   
        (...)

        logging.debug("form - save")
        post = super(EventForm, self).save(*args, **kwargs)
        post.save()

在我的调试中,我发现有太多的__init__

2010-10-28 23:35:08,210 DEBUG form - init
2010-10-28 23:35:34,065 DEBUG form - init
2010-10-28 23:35:34,068 DEBUG form - save
2010-10-28 23:35:34,073 DEBUG form - init
2010-10-28 23:35:34,258 DEBUG form - init
2010-10-28 23:35:34,262 DEBUG form - save
2010-10-28 23:35:34,270 DEBUG form - init

有人能帮忙吗?


编辑:

移除jquery-ui后仍然相同。移除livequery也没有结果。


部分解决。原来是我在导入函数发送数据时重复了导入。现在表单只发送一次,但重新发送后仍然得到一个原始的HTML表单。 - sasklacz
1个回答

1
为什么在保存原始表单后要实例化一个新表单?
if form.is_valid():
    form.save()
    # what's the point of the next line?
    form = EventForm(instance=event)

这几乎肯定是导致您重复调用__init__的原因。为什么要这样做?你已经有一个表单了。

此外,您忘记了在JS中停止单击操作的完成。

$("#event-data-save").livequery("click", function(e) {
    e.preventDefault();
    ...
})

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接