Это моя функция ajax:
function ajax_call(call_method,data_to_send) {
logger("function ajax_call. var data_to_send: ");
logger(data_to_send);
$('.clickable save_button').hide()
$.ajax({
type: 'POST',
url: call_method,
data: data_to_send,
success: function(data){
logger("data returned to page after ajax call: ");
logger(data);
$('.error_msg').html("Successfully saved record to database.");
$('.error_msg').fadeIn('slow');
setTimeout("$('.error_msg').fadeOut('slow');",5000); // 5 secs to give user enough time to read
$('.clickable save_button').show()
response_dispatcher(data); // This should contain object type at least
},
failure: function(){
$('.error_msg').html("There was an error while saving this information. Please try again. " +
"If the error persists, please contact us using the contact form.");
$('.error_msg').show;
$('.clickable save_button').show()
},
dataType: 'json'
});
}
И это данные, отправленные моему методу на бэкэнд: {'display_order': "3", 'goal': "dummy goal",'id': - 1, 'object_type': "goal"}
Я проверил в своем приложении, что получены те же самые данные.
Вот мой метод просмотра Django:
@login_required
def update_goal_view(request):
if request.method == 'POST' and request.is_ajax:
# Example data sent from AJAX Request
#qd = {u'display_order': [u'23'], u'object_type': [u'goal'], u'goal': [u'dummy goal'], u'id': [u'-1']}
qd = request.POST
goal = qd.get('goal','')
display_order = qd.get('display_order',99999)
id = int(qd.get('id',''))
object_type = qd.get('object_type','')
# For now, just return something to test populating data to the page
id = '100'
goal = 'goal returned'
object_type = object_type
data = {'id':id,'goal':goal,'object_type':object_type}
return HttpResponse(data,mimetype="application/json")
В Firebug я вижу это после вызова ajax:
POST http://127.0.0.1/xml/update_goal 200 OK 12ms
Проблема заключается в том, что когда кажется, что мой успешный обратный вызов никогда не вызывается ... Я говорю это, потому что, какВы можете видеть сверху, я должен был написать сообщение в мой логгер, но его нет.Я знаю, что мой регистратор работает из-за всех других сообщений вне обратного вызова, которые записываются в мой регистратор.