backbone中get和fetch的区别

如题所述

第1个回答  2015-07-28
在backbone中,get是用来获取模型中defaults 的数据的,我们都知道模型中有一个叫做defaults 的属性,而这个属性可能会有很多的数据,比如:
1 World = Backbone.Model.extend({
2 defaults: {
3 x: '1',
4 y: '2'
5 }
6 });

这里面defaults的数据"x"和"y"就可以用get来获取了:
1 var data=new World();
2 alert(data.get('x'));

这个就是get的用法。下面我们再来说说fetch的用法吧!
还是在backbone的模型中有一个URL的属性,用这个属性可以访问远程的数据,从而更好的跟后台结合,下面就是用URL获取远程JSON的示例:
1 World = Backbone.Model.extend({
2 url:'123.json'
3 });

远程的JSON如下:
1 {
2 "employees": [
3 { "firstName":"Bill" , "lastName":"Gates" },
4 { "firstName":"George" , "lastName":"Bush" },
5 { "firstName":"Thomas" , "lastName":"Carter" }
6 ]
7 }

下面我们要想获取这些数据就要用到fetch这个方法了:
1 var data=new World();
2 data.fetch({
3 success:function(model, text){
4 alert.log(text.employees);
5 },
6 error:function(){
7 alert("报错!");
8 }
9 });

其中fecht有三个返回参数,(参考 原版API )(model, response, options), 其中model就是返回当前的模型,在这个例子中就是data了。response就是返回的数据了,在此例子中就是text,而oprions现在我还没搞明白o(╯□╰)o~所以希望有知道的高手不吝赐教~
说到这里还有一个就是fetch获取回数据后会添加给模型的defaults属性,然后用get获取其中的数值,当然这些都是fetch来模拟实现的了本回答被提问者和网友采纳