我也是刚开始接触backbone.js对于里面的很多东西都看过,但是具体在使用起来还是有很多问题,其中一个就是get和fetch的区别,这个让我很纠结,都是获取模型的数据,干嘛要有两个呢?最近好像弄明白了点,发到网上欢迎高手拍砖~!
先说说get,在backbone中,get是用来获取模型中defaults的数据的,我们都知道模型中有一个叫做defaults的属性,而这个属性可能会有很多的数据,比如:
World = Backbone.Model.extend({
defaults: {
x: '1',
y: '2'
}
});
这里面defaults的数据"x"和"y"就可以用get来获取了:
var data=new World();
alert(data.get('x'));
这个就是get的用法。下面我们再来说说fetch的用法吧!
还是在backbone的模型中有一个URL的属性,用这个属性可以访问远程的数据,从而更好的跟后台结合,下面就是用URL获取远程JSON的示例:
World = Backbone.Model.extend({
url:'123.json'
});
远程的JSON如下:
{
"employees": [
{ "firstName":"Bill" , "lastName":"Gates" },
{ "firstName":"George" , "lastName":"Bush" },
{ "firstName":"Thomas" , "lastName":"Carter" }
]
}
下面我们要想获取这些数据就要用到fetch这个方法了:
var data=new World();
data.fetch({
success:function(model, text){
alert.log(text.employees);
},
error:function(){
alert("报错!");
}
});
其中fecht有三个返回参数,(参考原版API)(model, response, options),其中model就是返回当前的模型,在这个例子中就是data了。response就是返回的数据了,在此例子中就是text,而oprions现在我还没搞明白o(╯□╰)o~所以希望有知道的高手不吝赐教~
说到这里还有一个就是fetch获取回数据后会添加给模型的defaults属性,然后用get获取其中的数值,当然这些都是fetch来模拟实现的了~具体的内容有感兴趣的同学自己去研究一下原版的BAKCBONE吧~就到这里~不对的地方希望大家指正~