オブジェクトの編集ページがあります。データを2つのタブに分けているので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;
})
そして関数が実行され、私のデバッグはそれが即座に2回呼び出されると言います:
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__'s
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 を削除しても結果は得られません。