• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >AngularJS > 详解AngularJs中$resource和restfu服务端数据交互

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含restfu,angularjs resource,angularjs 详解,angularjs 路由详解,resource等相关知识,希望在学习及工作中可以帮助到您

$resource

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

安装

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

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

$resource应用

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

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

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

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

User.get({id:'123'}, successFn, errorFn);
</div>

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

User.query(params, successFn, errorFn)
</div>

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

save(params, payload, successFn, errorFn);
</div>

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

delete(params, payload, successFn,errorFn)
</div>

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

remove(params, payload, successFn, errorFn)
</div>

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

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

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

$resource扩展

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

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

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

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

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

总结

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

</div>

您可能想查找下面的文章:

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

相关文章

  • 2017-05-30关于AngularJs数据的本地存储详解
  • 2017-05-30Angular.Js中过滤器filter与自定义过滤器filter实例详解
  • 2017-05-30Angularjs使用指令做表单校验的方法
  • 2017-05-30解决angular的$http.post()提交数据时后台接收不到参数值问题的方法
  • 2017-05-30angularjs+bootstrap菜单的使用示例代码
  • 2017-05-30angularjs ui-router中路由的二级嵌套
  • 2017-05-30如何用angularjs制作一个完整的表格
  • 2017-05-30AngularJS 在同一个界面启动多个ng-app应用模块详解
  • 2017-05-30AngularJS表单提交实例详解
  • 2017-05-30AngularJS教程 ng-style 指令简单示例

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • AngularJS ng-repeat指令中使用track by子语句解决重复数据遍历错误问题
    • AngularJS教程之MVC体系结构详解
    • AngularJS 2.0新特性有哪些
    • AngularJs根据访问的页面动态加载Controller的解决方案
    • AngularJS压缩JS技巧分析
    • angularjs 处理多个异步请求方法汇总
    • Angularjs根据json文件动态生成路由状态的实现方法
    • Angular实现form自动布局
    • AngularJS 在同一个界面启动多个ng-app应用模块详解
    • AngularJS基础 ng-init 指令简单示例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有