详解AngularJs中$resource和restfu服务端数据交互


Posted in Javascript onSeptember 21, 2016

$resource

创建一个resource对象的工厂函数,可以让你安全的和RESFUL服务端进行数据交互。

安装

ngResource模块是一个可选的angularjs模块,如果需要使用,我们要单独引用js

<script type="text/javascript" src="/javascripts/angular-resource.js">

$resource应用

我们并不是直接通过$resource服务本身同服务器通信,$resource是一个创建资源对象的工厂,用来创建同服务端交互的对象。

var User = $resource('/api/users/:userId', {userId:'@id'});

返回的User对象包含了同后端服务进行交互的方法,我们可以把User对象理解成同RESTFul的后端服务进行交互的接口。

该对象包含两个get类型的方法已经三个非get类型的方法。

User.get({id:'123'}, successFn, errorFn);

该方法向url发送一个get请求,并期望一个json类型的响应。这里会向/api/users/123发送一个请求,successFn处理请求成功响应,errorFn处理错误。

User.query(params, successFn, errorFn)

get()方法使用类似,一般用来请求多条数据。

save(params, payload, successFn, errorFn);

save方法会发起一个post请求,params参数用来填充url中变量,对象payload会作为请求体进行发送

delete(params, payload, successFn,errorFn)

delete方法一个DELETE请求,payload作为消息体进行发送

remove(params, payload, successFn, errorFn)

同delete类似,不同的是remove用来移除多条数据

通过$resource生成的对象来同服务器进行交互的时候,我们看可以定义处理成功以及处理失败的函数,这些函数接受的参数不仅仅是简单的对象,而是经过包装之后的对象,会被添加$save() , $remove() , $delete三个方法,可以直接调用这三个方法来后服务端进行交互。

User.get({id:'123'}, function(user){
 user.name = 'changeAnotherName';
 user.$save();
//这里等价于User.save({id:'123'},{name:'changeAnotherName'})
});

$resource扩展

$resource对常见的五种请求进行封装,我们还可以对$resource进行扩展。

这里要扩展$resource我们需要传入第三个参数,该参数是一个对象。

$resource('/api/users',{},{
 sendEmail:{
  method:'',
  url:'',
  params:{},
  isArray:boolean,
  transformRequest:函数或者函数数组
  transformResponse:函数或者函数数组
  cache:布尔型或缓存对象
  timeout:数值或promise对象
  withCredentials:布尔类型
  responseType:字符串,用来设置XMLHttpRequestResponseType属性
 }
})

我们也可以将$resource服务当做自定义服务的基础。

angular.module('testApp', ['ngResource']),factory('UserService',['$resource', function($resource){
  return $resource(url,{},{});
}]);

总结

以上就是关于AngularJs中$resource和restfu服务端数据交互的全部内容,希望这篇文章对大家学习或者使用AngularJS能有所帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
关于jQuery $.isNumeric vs. $.isNaN vs. isNaN
Apr 15 Javascript
confirm的用法示例用于按钮操作时确定是否执行
Jun 19 Javascript
jQuery1.9.1源码分析系列(十六)ajax之ajax框架
Dec 04 Javascript
javascript实现下雪效果【实例代码】
May 03 Javascript
js与jquery分别实现tab标签页功能的方法
Nov 18 Javascript
鼠标点击input,显示瞬间的边框颜色,对之修改与隐藏实例
Dec 26 Javascript
react-router实现跳转传值的方法示例
May 27 Javascript
深入理解Vue.js源码之事件机制
Sep 27 Javascript
vue.js移动数组位置,同时更新视图的方法
Mar 08 Javascript
JavaScript执行环境及作用域链实例分析
Aug 01 Javascript
javascript实现左右缓动动画函数
Nov 25 Javascript
编写v-for循环的技巧汇总
Dec 01 Javascript
AngularJS通过$http和服务器通信详解
Sep 21 #Javascript
JavaScript 拖拽实例代码
Sep 21 #Javascript
Angularjs中controller的三种写法分享
Sep 21 #Javascript
jQuery中Find选择器用法示例
Sep 21 #Javascript
jQuery实现点击后高亮背景固定显示的菜单效果【附demo源码下载】
Sep 21 #Javascript
Angular2 (RC5) 路由与导航详解
Sep 21 #Javascript
Angular2 (RC4) 路由与导航详解
Sep 21 #Javascript
You might like
用Zend Encode编写开发PHP程序
2010/02/21 PHP
php 常用类汇总 推荐收藏
2010/05/13 PHP
ThinkPHP3.1之D方法实例详解
2014/06/20 PHP
解决更换PHP5.4以上版本后Dedecms后台登录空白问题的方法
2015/10/23 PHP
php批量转换文件夹下所有文件编码的函数类
2017/08/06 PHP
php微信开发之谷歌测距
2018/06/14 PHP
JavaScript 利用StringBuffer类提升+=拼接字符串效率
2009/11/24 Javascript
jQuery Validation插件remote验证方式的Bug解决
2010/07/01 Javascript
ActiveX控件与Javascript之间的交互示例
2014/06/04 Javascript
我的Node.js学习之路(三)--node.js作用、回调、同步和异步代码 以及事件循环
2014/07/06 Javascript
js实现精美的银灰色竖排折叠菜单
2015/05/16 Javascript
实例详解JavaScript获取链接参数的方法
2016/01/01 Javascript
解读Bootstrap v4 sass设计
2016/05/29 Javascript
全面了解javascript中的错误处理机制
2016/07/18 Javascript
vue-resource:jsonp请求百度搜索的接口示例
2019/11/09 Javascript
微信小程序swiper使用网络图片不显示问题解决
2019/12/13 Javascript
[00:17]游戏风云独家报道:DD赛后说出数字秘密 吓死你们啊!
2014/07/13 DOTA
python使用urllib模块开发的多线程豆瓣小站mp3下载器
2014/01/16 Python
python中Apriori算法实现讲解
2017/12/10 Python
python取代netcat过程分析
2018/02/10 Python
Python使用logging模块实现打印log到指定文件的方法
2018/09/05 Python
使用django-guardian实现django-admin的行级权限控制的方法
2018/10/30 Python
Python爬取腾讯视频评论的思路详解
2019/12/19 Python
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
2020/07/01 Python
Python延迟绑定问题原理及解决方案
2020/08/04 Python
eDreams澳大利亚:预订机票、酒店和度假产品
2017/04/19 全球购物
全世界最美丽的四星和五星级酒店预订:Prestigia.com
2017/11/15 全球购物
安全的后院和健身蹦床:JumpSport
2019/07/15 全球购物
应届中专生自荐书范文
2014/02/13 职场文书
三好学生评语大全
2014/12/29 职场文书
2015入党自传书范文
2015/06/26 职场文书
Django给表单添加honeypot验证增加安全性
2021/05/06 Python
详解运行Python的神器Jupyter Notebook
2021/06/03 Python
使用canvas对video视频某一刻截图功能
2021/09/25 HTML / CSS
vue使用wavesurfer.js解决音频可视化播放问题
2022/04/04 Vue.js
python中pycryto实现数据加密
2022/04/29 Python