2

Post の ContentType を json/application に指定する方法を知っている人はいますか? 私はそう思っていましたが、バックボーンはデフォルトでそれを行いましたが、プレーンテキストを取得していると言っているという事実から判断すると(コメントを参照)、それを指定する別の方法を理解する必要があると思います.

Backbone.js を使用しており、読み取り専用ではなくなった TastyPie API に POST しようとしています。モデルを作成して .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;
        });

    });


    });
4

1 に答える 1

3

Backbone.emulateJSON = true;コードで設定してみてください。

これが true に設定されている場合、contentType探している 'application/json' に設定されます。

この変数を設定する必要があるのは 1 回だけなので、適切な場所はフォーム送信コードのすぐ上です。

$(function() {
    Backbone.emulateJSON = true;
    $('form').submit(function() {
        ...
于 2012-01-15T14:24:21.803 に答える