3

なぜ私がレールを使用しないのか、人々はおそらく本当に混乱するでしょうが、私はphpを使用する方が気分が良いので、それを選びました。私は基本的に本当に単純なbackbone.jsを作成しようとしています。urlRoot関数とurl関数を事前定義しました。phpをコーディングして、単にメッセージを返すようにしました(echoを使用)。

しかし、私が何をしようとも、私が応答を受け取ろうとするときはいつでも、それは常にエラーコールバックに落ちます。応答でresponseTextを取得しますが、エラーコールバックがトリガーされる理由を理解できません。これが私の完全なhtmlとバックエンドのphpコードです。なぜ常にエラーコールバックに行くのですか?また、ヘッダーを受け取ったことを述べたいと思います

HTTP/1.1 200 OK

HTML(Backbone.jsも含まれています);

<html>
<head>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
    <script src="http://ajax.cdnjs.com/ajax/libs/json2/20110223/json2.js"></script>
    <script src="http://ajax.cdnjs.com/ajax/libs/underscore.js/1.1.6/underscore-min.js"></script>
    <script src="http://ajax.cdnjs.com/ajax/libs/backbone.js/0.3.3/backbone-min.js"></script>
</head>
<body>
<div id='place'>
    <input id='clicker' type='button' value='Click Me'/>
</div>
<script type='text/javascript'>
(function($){
    Backbone.emulateHTTP=true;
    Backbone.emulateJSON=true;
    var URL=Backbone.Model.extend({
        initialize:function(){
            console.log("URL object has been created");
        },
        defaults:{
            url:'not actually defined'
        },
        urlRoot:'/StupidExample/server.php',
        url:function(){
            var base=this.urlRoot || (this.collection && this.collection.url) || "/";
            if(this.isNew()) return base;

            return base+"?id="+encodeURIComponent(this.id);
        }
    });

    var URLView=Backbone.View.extend({
        initialize:function(){
            console.log('URL View has been created');
        },
        el:('#place'),
        events:{
            "click #clicker":"alerter"
        },
        alerter:function(){
            console.log("I've been clicked");
            var obj=new URL();
            obj.save(obj.toJSON,{
            success:function(){
                console.log("Success")
            },
            error:function(model,response,xhr){
                console.log(model);
                console.log(response);
                console.log(xhr);
                console.log("Error");
            }
            });
        }
    });

    var urlView=new URLView();
})(jQuery);
</script>
</body>
</html>

PHP;

<?php
echo "I've received something";
?>
4

2 に答える 2

11

HTTP 200応答とともに有効なJSONオブジェクトを返す必要があります。バックボーンはecho、応答をJSONとして解析しようとするため、戻り値にエラーをスローしますが、失敗します。

于 2012-05-20T17:53:42.193 に答える
1

Derickが言ったように、JSONを返す必要があります。これは、phpファイルを次のように変更することで実行できます。

 <?php print json_encode(array( 'response' => 'success' ));

ただし、AJAXはドメイン間で許可されていないため、URLとして絶対パスを使用しない必要があります。そのため、相対パスである必要があります。

于 2012-05-20T18:19:28.703 に答える