Backbone.js:Save的成功函数根本不起作用

时间:2012-05-19 17:43:25

标签: php javascript backbone.js

我正在尝试在Backbone.js中运行最基本的东西,但不知何故失败了。我为将 url 模型保存到服务器而生成的代码。

urlToAdd.set({url: urlBody.value, tags:tagsToAdd});
                urlToAdd.save({
                    success:function(){
                        console.log('it works');
                    }
                });

成功将数据发送到我的php页面但是我无法获得成功事件。我哪里做错了?我仔细观察过,找不到任何东西。

这是我的模型定义:(不幸的是,因为我是骨干菜鸟,我通过检查教程应用了这个,我不知道 url 功能中的代码是否必要

var URLWithTags=Backbone.Model.extend({
            initialize:function(){
                console.log('URL object has been initialized');
            },
            defaults:{
                url:'not defined',
                tags:[]
            },
            validate:function(attributes){
            //console.log(attributes.tags[0].length);
                /*if(attributes.tags[0].length<1)
                    return "You should create at least one tag";*/
            },
            urlRoot:'/URLTags/manage.php',
            url:function(){
                var base = this.urlRoot || (this.collection && this.collection.url) || "/";
                console.log("Base has been produced");
                if(this.isNew())
                    return base;

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

1 个答案:

答案 0 :(得分:2)

当您调用save函数时,Save应该是对象中的第二个参数。 请人们阅读文档,或者文章评论很好,简短易读。

urlToAdd.save(null,{success:function(){console.log('it works')}});

根据文件:

savemodel.save([attributes], [options]) ;

所以:

urlToAdd.save({},{success:successCallback , error:errorCallback}); 

修改

例如:

    var Car,yukon,$target ;
    Object.prototype.toString = function(){
        return JSON.stringify(this);
    };

    Car = Backbone.Model.extend({
        url:"/echo/json"
    });
    yukon= new Car({"color":"red","brand":"GM"});
    $target = $("#target");

    $target.append("describe yukon :",yukon.toString(),"<br/>");

    yukon.save({},
{
success:function(o){$target.append("save success <br/>",o.toString())},
error:function(e){$target.append("error",e)}
}
); 

其中$ target是一个jquery对象,表示id为target的div。