如何正确处理AngularJS 1.2中的资源?
发布时间:2020-12-17 16:58:44 所属栏目:安全 来源:网络整理
导读:我昨天将AngularJS从1.0.7更新到1.2rc1以检查新功能.一切正常,但我遇到了ngResource的一些问题.有了这些工厂,我得到一个json文件的虚拟数据: angular.module('RESTServices',['ngResource']) .factory('Customer',function($resource){ return $resource(ba
我昨天将AngularJS从1.0.7更新到1.2rc1以检查新功能.一切正常,但我遇到了ngResource的一些问题.有了这些工厂,我得到一个json文件的虚拟数据:
angular.module('RESTServices',['ngResource']) .factory('Customer',function($resource){ return $resource(base+'customer.json',{},{ 'query' : { method: 'GET',isArray: true,cache: caching } }); }); 我将RESTService注入控制器并使用它: Customer.query({},function(response){ $scope.customers = response; }); 一方面,他们是$scope.customers中的一系列客户,另一方面,他们是响应中的其他对象($promise和$resolved).控制台的屏幕截图显示了解析对象. 如果我想迭代响应,迭代器遍布200个客户和$promise和$resolved对象,我得到错误,因为我的代码不知道如何处理这些对象.在版本1.0.7中,响应中只有200个客户. 我错了吗?如果不是$resolved或$response,我必须在迭代时检查每个项目吗?文档目前尚不清楚. 解决方法
问题是我如何迭代响应.
我变了 for(item in items){ for(attr in attributes){ if(items[item][attributes[attr]].toLowerCase().indexOf(filterString) != -1){ matchedItems.push(items[item]); break; } } } 至 for(var i = 0; i < items.length; i++){ for(attr in attributes){ if(items[i][attributes[attr]].toLowerCase().indexOf(filterString) != -1){ matchedItems.push(items[i]); break; } } } 一切正常. AngularJS关注正确的长度值,因此我可以将它用于for循环,而不是迭代响应中的所有值(包括所有值和$promise和$resolved). (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |