一、$resource服务介绍

$http服务提供的实现极为简单和低级,可以用来发送XHR请求,同时它还为你提供了很大的可控性和灵活性。但是,在大多数情况下,我们需要处理对象,以及封装了特定属性和方法的对象模型,例如一个person对象(带有详细信息),或者一个信用卡对象。
$resource就是为这一功能而设计的。AngularJS中的resource(资源)允许我们用描述性的方式来定义对象模型,它可以描述以下内容:
使用Angular所提供的$resource对象,你可以根据各种需求查询服务器;除此之外,你还可以把服务端返回的对象当成已经持久好的数据模型,你可以修改它们,并且可以把它们持久化。
ngResource是一个独立的、可选的模块,因此,并没有默认包含在Angular中, 为了使用它,需要:
1、在加载的脚本文件中包含angular-resource.js.
例如: <script src="http://cdn.bootcss.com/angular-resource/1.5.8/angular-resource.min.js"></script>
2、在模块依赖声明中包含ngResource
例如: angular.module(‘myapp', [‘ngResource'])
3、在需要的地方使用注入的$resource服务。
格式: var obj=$resource(url,[,paramsDefaults],[,actions])
obj表示请求服务器指定url地址后返回的`$resource`对象,该对象中就包含了**与服务端进行数据交互的全部API**。
参数url表示请求服务器的地址,其中允许占位符变量,该变量必须以`:`为前缀
例如:
`var obj=$resource('url?action=:act');`
`obj.$save{act:'save'}`
那么,在执行save动作时,向服务端发送的实际地址就为`url?action=save`。
此外,可选参数`paramsDefaults`是一个对象,用于设置请求时的默认参数值,在发送请求时,该对象中的全部值将自动进行序列化,如遇占位符变量自动替换,并将结果添加到url请求之后
代码如下:
var obj=`$resource`('url?action=:act',{
act:'save',
a:'1',
b:'2'
});
执行上述代码后,向服务器发送的实际地址是`url?action=save&a=1&b=2`。
另外一个可选参数`actions`的功能是扩展默认资源动作,例如,可以在该对象中自定义新的方法:
var boj=$resource('url?action=:act',{
...
},{
a:{
method:'get'
}
});
然后就可以在$resource对象中直接调用在可选参数actions中自定义的方法a,即obj.$a()
二、 $resource服务所返回娿对象中所包含的5个与服务端交互常用API
1、$resource服务返回对象中的GET类型请求
包含两个api,分别为get query,调用格式如下:
var obj=$resource('url');
//get()方法
obj.get(params,successFn,errorFn);
//query方法
obj.query(params,successFn,errorFn);
这两个api的请求参数相同,区别在于,**get返回值可以是单个资源,但是query必须返回一个数组或集合类的资源。**
2、$resource服务返回对象中的非GET类型请求
包含3个api,分别为save delete remove,调用格式如下:
var obj=$resource('url');
//save()方法
obj.save(params,postData,successFn,errorFn);
//delete方法
obj.save(params,postData,successFn,errorFn);
//remove方法
obj.save(params,postData,successFn,errorFn);
其中,delete方法和remove方法作用享用,区别在于remove可以解决IE浏览器中delete是Javascript保留字而导致的错误问题。
<div ng-controller='myController'>
<ul>
<li ng-repeat='item in items'>
<span>{{item.Code}}</span>
<span>{{item.Name}}</span>
<span>{{item.Gender}}</span>
</li>
</ul>
<div>
Key: <input type="text" ng-model='key' />
<button ng-click='save()'>保存</button>
<div>{{result}}</div>
</div>
</div>
<script type="text/javascript">
angular.module('myapp',['ngResource'])
.config(function($httpProvider){
$httpProvider.defaults.transformRequest=function(obj){
var arrStr=[];
for(var p in obj){
arrStr.push(encodeURIComponent(p)+"="+encodeURIComponent(obj[p]));
}
return arrStr.join("&");
};
$httpProvider.defaults.headers.post={
'Content-Type':'application/x-www-form-urlencoded'
}
})
.controller('myController',['$scope','$resource',function($scope,$resource){
var stus=$resource('/info');
///info?action=search
stus.query({action:'search'},function(resp){
$scope.items=resp;
});
$scope.save=function(){
var data={
key:$scope.key
};
stus.save({action:'save'},data,function(resp){
$scope.result=(resp[0]=='1')?'保存成功':"保存失败";
});
}
}])
</script>
对应的服务器端文件,使用了Express架构,核心代码如下:
//对于query请求
app.get('/info',function(req,res){
var info=[
{Code:'1001',Name:'zhangsan',Gender:'female'},
{Code:'1002',Name:'lisi',Gender:'male'}
];
res.status(200).json(info);
});
//对于save请求
app.post('/info',function(req,res){
if(req.body.key=='1001'){
res.send('1');
}else{
res.send('0')
}
});
三、在$resource服务中自定义请求方法
var obj=$resource(url,[,paramsDefaults],[,actions])
在第三个可选参数中,通过key/value的方式自定义。
<div ng-controller='myController'>
<div>
<div>{{r0}}</div>
<div>{{r1}}</div>
<div>{{r2}}</div>
<button ng-click='click()'>开始</button>
</div>
</div>
<script type="text/javascript">
var url='/self?action=:act';
angular.module('myapp',['ngResource'])
.config(function($httpProvider){
$httpProvider.defaults.transformRequest=function(obj){
var arrStr=[];
for(var p in obj){
arrStr.push(encodeURIComponent(p)+"="+encodeURIComponent(obj[p]));
}
return arrStr.join("&");
};
$httpProvider.defaults.headers.post={
'Content-Type':'application/x-www-form-urlencoded'
}
})
.factory('custom',['$resource',function($resource){
return $resource(url,{act:'search'},
{
update:{
method:'POST',//使用POST方式请求服务器
params:{
update:true
},
isArray:false //表示调用该方法后,服务器返回的数据可以不是一个数组
}
});
}])
.controller('myController',['$scope','custom',function($scope,custom){
$scope.click=function(){
//这里的id是放在url后面的,/self?action=search&id=1001
custom.get({id:'1001'},function(resp0){
$scope.r0=(resp0[0]=='1')?'查找成功':'查找失败';
resp0.key='1001';
// /self?action=update&update=true
resp0.$update({act:'update'},function(resp1){
$scope.r1=(resp0[0]=='1')?'更新成功':'更新失败';
//这里的key是放在数据body体里面的
resp1.key='1002';
//self?action=save
resp1.$save({act:'save'},function(resp2){
$scope.r2=(resp0[0]=='1')?'保存成功':'保存失败';
})
})
})
}
}])
</script>
对应的服务器端文件,使用了Express架构,核心代码如下:
// /self?action=search&id=1001
app.get('/self',function(req,res){
if(req.query.action=='search'){
console.log('req.params.id:'+req.params.id);
if(req.query.id=='1001'){
res.send('1');
}else{
res.send('0');
}
}
});
// /self?action=update&update=true /self?action=save
app.post('/self',function(req,res){
if(req.query.action=='update'){
if(req.body.key=='1001' && req.query.update=='true'){
res.send('1');
}else{
res.send('0');
}
}else if(req.query.action=='save'){
if(req.body.key=='1002'){
res.send('1');
}else{
res.send('0');
}
}
})
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
# angularjs
# resource
# angular
# resource详解
# 详解AngularJs中$resource和restfu服务端数据交互
# 浅谈AngularJS中使用$resource(已更新)
# 可选
# 服务端
# 自定义
# 象中
# 你可以
# 是一个
# 放在
# 分别为
# 装了
# 这一
# 使用了
# 为你
# 你还
# 这两个
# 并将
# 它可以
# 另外一个
# 这篇文章
# 第三个
# 所提供
相关文章:
如何在Windows服务器上快速搭建网站?
非常酷的网站设计制作软件,酷培ai教育官方网站?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
高端建站如何打造兼具美学与转化的品牌官网?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
如何快速生成凡客建站的专业级图册?
名字制作网站免费,所有小说网站的名字?
如何快速搭建二级域名独立网站?
如何零成本快速生成个人自助网站?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
建站之星收费标准详解:套餐费用及年费价格表一览
如何用好域名打造高点击率的自主建站?
西安专业网站制作公司有哪些,陕西省建行官方网站?
如何确认建站备案号应放置的具体位置?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
建站之星后台密码如何安全设置与找回?
官网网站制作腾讯审核要多久,联想路由器newifi官网
如何通过FTP服务器快速搭建网站?
免费网站制作appp,免费制作app哪个平台好?
音响网站制作视频教程,隆霸音响官方网站?
建站主机如何选?高性价比方案全解析
如何在IIS7中新建站点?详细步骤解析
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
C++时间戳转换成日期时间的步骤和示例代码
如何通过商城免费建站系统源码自定义网站主题?
如何快速生成橙子建站落地页链接?
建站之星代理费用多少?最新价格详情介绍
南京网站制作费用,南京远驱官方网站?
,交易猫的商品怎么发布到网站上去?
网站制作价目表怎么做,珍爱网婚介费用多少?
建站之星安装提示数据库无法连接如何解决?
免费视频制作网站,更新又快又好的免费电影网站?
建站之星如何开启自定义404页面避免用户流失?
宝塔新建站点为何无法访问?如何排查?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
网站设计制作公司地址,网站建设比较好的公司都有哪些?
建站之星后台密码遗忘如何找回?
建站之星代理商如何保障技术支持与售后服务?
网站制作员失业,怎样查看自己网站的注册者?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
建站主机是什么?如何选择适合的建站主机?
高端企业智能建站程序:SEO优化与响应式模板定制开发
如何在Ubuntu系统下快速搭建WordPress个人网站?
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
如何在西部数码注册域名并快速搭建网站?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。