2012-01-15 63 views
2

有谁知道如何指定Post的jQuery /应用程序的ContentType?我以为自己是,骨干在默认情况下是这样做的,但根据事实说它得到纯文本(请参阅评论),我想我需要找出另一种方式来指定它。Backbone.js后500错误

我正在使用Backbone.js,我试图发布到不再只读的TastyPie API,当我尝试制作模型和.save()时,我收到500错误。这是一个代码片段,我使用我同步,我发现这里: http://documentcloud.github.com/backbone/docs/backbone.html#section-124

Backbone.sync = function(method, model, options){ 
     var type = methodMap[method]; 
     var params = _.extend({ 
     type: type, 
     dataType: 'json' 
     }, options); 

     if (!params.url){ 
     params.url = getUrl(model) || urlError(); 
     } 

     if (Backbone.emulateJSON){ 
     params.contentType = 'application/json'; 
     params.data = params.data ? {model: params.data} : {}; 
     } 

     if (Backbone.emulateHTTP){ 
     if(type === 'PUT' || type === 'DELETE'){ 
      if (Backbone.emulateJSON) params.data._method = type; 
      params.type = 'POST'; 
      params.beforeSend = function (xhr){ 
       xhr.setRequestHeader('X-HTTP-Method-Override', type); 
      }; 
     } 
     } 

     if (params.type !== 'GET' && ! Backbone.emulateJSON){ 
     params.prorcessData = false; 
     } 

     return $.ajax(params); 
     }; 





    $.fn.serializeObject = function() 
    { 
     var o = {}; 
     var a = this.serializeArray(); 
     $.each(a, function() { 
     if (o[this.name] !== undefined) { 
      if (!o[this.name].push) { 
      o[this.name] = [o[this.name]]; 
      } 
      o[this.name].push(this.value || ''); 
     } else { 
      o[this.name] = this.value || ''; 
     } 
     }); 
     return o; 
    }; 

    $(function() { 
     $('form').submit(function() { 
     var dict = $('form').serializeObject(); 
     var new_task = new Backbone.Model({ 
     date: toString(dict.date), 
     name: toString(dict.name), 
     priority: toString(dict.priority)}); 
     console.log("new_task =" + new_task); 
     new_task.save(); 
     console.log(dict); 

     return false; 
     }); 

    }); 


    }); 
+0

这就是“常规” backbone.sync吧?你会得到什么样的500回应?我最近做了一个应用程序,结合了tastypie和主干。你可以看看这里:https://github.com/c4urself/ratebeer也许它会给你一些想法。 – c4urself 2012-01-15 11:33:22

+0

:“格式为'text/plain'没有可用的反序列化方法,请检查你的序列化程序中的''formats''和'content_types'”, – user784756 2012-01-15 11:45:28

+0

这里的一个障碍是,尽管Paul的解决方案是正确的, Tastypie还不支持X-HTTP-Method-Override标头。你可以使用类似这样的东西来添加或直接使用覆盖的方法扩展你正在使用的Resource类:https://gist.github.com/2161338 – 2012-03-22 18:55:48

回答

3

尝试在你的代码中设置Backbone.emulateJSON = true;

如果设置为true,那么它会将contentType设置为您正在查找的“application/json”。

你只需要一次设置此变量,所以一个好的地方就上述表单提交的代码

$(function() { 
    Backbone.emulateJSON = true; 
    $('form').submit(function() { 
     ...