我也是刚开始接触backbone.js对于里面的很多东西都看过,但是具体在使用起来还是有很多问题,其中一个就是get和fetch的区别,这个让我很纠结,都是获取模型的数据,干嘛要有两个呢?最近好像弄明白了点,发到网上欢迎高手拍砖~!
先说说get,在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来模拟实现的了~具体的内容有感兴趣的同学自己去研究一下原版的BAKCBONE吧~就到这里~不对的地方希望大家指正~