AngularJS中使用ajax获取数据的最佳方式是什么
What is the best way in AngularJS to get data using ajax
我有一个名为MoviesListsCtrl
的控制器,它使用ng控制器应用于html文档中的3个元素。
如果我在控制器内部使用$http
服务,对于相同的数据,它将被执行3次。
用ajax检索一次json数据并将其用于控制器的最佳方法是什么。
如果是GET请求,那么您可以缓存响应,这样只进行一次调用,所有后续调用都将从缓存中提取。
$http({
url: "someUrl",
cache: true
}).success(function(){
// do something
}).error(function(){
// do something else
});
您的代码仍然会运行多次,因为您在每个元素上都有它,但它只会进行一次http调用。
使用Angular服务或工厂。您可以在服务中抽象掉$http
调用,这样您的控制器就可以始终使用相同的接口。
类似于:
angular.module('myModule')
.service('myService', function ($http, $q) {
var myData = null;
this.get = function (params) {
return myData
? $q.when(myData)
: $http.get('http://example.com/myEndpoint', params)
.success(function (data) {
myData = data;
});
};
});
这是初步的,但它符合一般的想法。(您可能希望保留对promise的引用,并将其传递回被调用者,这样在promise解决之前发生的多个请求就不会导致新的HTTP请求。)
之后,您可以将服务注入控制器,只需调用它即可获得所需的数据。这样做的好处是,您将始终调用相同的方法来获取数据。希望这能有所帮助,祝你好运。
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式