了解AngularJS $resource
多数AngularJS应用都需要一些CRUD操作. 你可以使用$resource服务快速的进行一个CRUD.
前提
$resource服务不包含在angular.js中
. 因为不是每个Angular应用都需要CRUD操作, 如果你需要使用$resource服务你必须首先引用angular-resource.js文件.
然后你需要把ngResource注入到你的app中:
1
|
angular.module( 'myApp' , [ 'ngResource' ]); |
我们这样做是因为$resource服务定义在ngResource模块中.
$resource是怎么工作的?
$resource和RESTful API工作. 这意味着你的的URLS应该类似于下面的模式
URL | HTTP Verb | Request Body | Result |
---|---|---|---|
/api/entries |
GET | empty | Returns all entries |
/api/entries |
POST | JSON String | Creates new entry |
/api/entries/:id |
GET | empty | Returns single entry |
/api/entries/:id |
PUT | JSON String | Updates existing entry |
/api/entries/:id |
DELETE | empty | Deletes existing entry |
为了在你的controller或者service中使用 $resource, 你需要声明一个对$resource的依赖
. 下面的代码展示了如何在你的自定义服务中使用$resource:
1
2
3
|
angular.module( 'myApp' ).factory( 'Entry' , fucntion($resource){ return $resource( '/api/entries/:id' ); }); |
$resource默认有5个方法:
get()
query()
save()
remove()
delete()
现在来看看怎么使用这些方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
angular.module( 'myApp' ).controller( 'ResourceController' , function ($scope, Entry) { var entry = Entry.get({ id: $scope.id }, function () { console.log(entry); }); // get() 返回单个entry var entries = Entry.query( function () { console.log(entries); }); //query() 返回所有的entry $scope.entry = new Entry(); //你可以实例化一个resource类 $scope.entry.data = 'some data' ; // $scope.entry= {data:'some data'} Entry.save($scope.entry, function () { //把$scope.entry序列化成一个JSON作为POST body }); Entry. delete ({ id: $scope.id }, function () { console.log( 'Deleted from server' ); }); }); |
get()
函数发起了一个GET请求 /api/entries/:id
. 在发送前我们把:id赋值为$scope.id. 注意了get()函数返回了一个空对象. 当数据从服务器返回的时候会自动填充到这个空对象. get()函数的第二个方法会在数据从服务器返回的时候执行. 你可以在这里把返回值赋值给$scope.
为什么使用空对象?
You might question the wisdom of showing an empty object initially. Actually it's a good thing because you can omit the callback passed toget()
function. 如果你只是想把model赋值给$scope而不关心数据是什么时候从服务器返回的, 你可以使用下面的方法:
1
|
$scope.entry = Entry.get({ id: $scope.id }); |
如果get不返回一个空对象的话, 你需要添加一个callback:
1
2
3
|
Entry.get({id: $scope.Id}, function (entry){ $scope.entry = entry; ); |
query()对
/api/entries
发起了一个get请求(注意了没有:id
) 并返回一个空数组 (不是一个简单的对象). 当数据从服务器返回的时候这个空对象会被填充.
save()
对 /api/entries
发起了一个post请求. 第一个参数是POST body. 第二个参数是callback, 当数据保存完成后触发. You might recall that the return value of the $resource()
function is a resource class. So, in our case, we can call new Entry()
to create an actual resource instance, set various properties to it and finally save the object to the back end.
delete()
和 remove() 都对
/api/entries/:id发起一个delete请求
使用 remove()
兼容IE
有些IE浏览器可能不支持delete()
. 可以使用remove兼容IE.
在resource类中我们只使用get() query() (在我们的例子中resource类是Entry
). 所有非GET的方法, 例如 save()和
delete()在
new Entry()的实例中能用
(在这我们把它称为 $resource
实例). 不同的是这些方法以$开头
1
2
3
|
$save() $ delete () $remove() |
看看$save()方法是怎么使用的:
1
2
3
4
|
$scope.entry = new Entry(); //这个对象有个$save()方法 $scope.entry.$save( function (){ console.log( 'data saved' ); }); // $scope.entry 序列化成JSON作为POST body被发送 |
为了支持update操作, 我们需要修改代码如下
1
2
3
4
5
6
7
|
angular.module( 'myApp' ).factory( 'Entry' , function ($resource){ return $resource( '/api/entries/:id' , {id: '@_id' },{ update: { method: 'PUT' } }); }); |
$resource()的第二个指示url的:id参数的值应该是什么. 这里设置为@_id, 当你调用$resource实例的$delete()和$update()的时候, :id的值会被设置为实例的_id属性. 这个是为PUT和DELETE请求使用的. 注意第三个参数. 这是一个map允许我们给resource类添加自定义的方法. 如果方法不是一个get请求的话, $resource实例会有一个以$开头的同名方法. 现在看看怎么使用$update方法:
1
2
3
4
5
6
7
|
$scope.entry = Entry.get({id:$scope.id}, function (){ //$scope.entry 是服务器返回来的 是一个Entry的实例 $scope.entry.data = 'something else' ; $scope.entry.$update( function (){ console.info( 'updated' ); }); }); |
当$update被调用, 会发生下面的东西:
AngularJS 知道$update()会触发一个对/api/entries/:id的PUT请求.
读取$scope.entry._id并将赋值给url的:id参数.
将$scope.entry作为一个请求体PUT个URL.
同样, 如果你想删除一个entry你可以这样做:
1
2
3
4
5
|
$scope.entry = Movie.get({id: $scope.id}, function (){ $scope.entry.$ delete ( function (){ //completed }); }); |
使用 MongoDB
如果你使用的是MongoDB, 你从后端获取到的$scope.entry实例通常有一个叫_id的属性. { id: '@_id' }
当调用$update()或者$delete()的时候, url的:id参数会被赋值为实例的_id属性 .
$resource第四个参数是可选的. 它是一个客户自定义的配置. 这里我们只设置 stripTrailingSlashes
. 默认情况下它的值是true, 这意味他会自动去除url的最后一个/. 如果你不想这样可以这样:
1
2
3
4
5
6
7
8
9
|
angular.module( 'myApp' ).factory( 'Entry' , function ($resource) { return $resource( '/api/entries/:id' , { id: '@_id' }, { update: { method: 'PUT' // this method issues a PUT request } }, { stripTrailingSlashes: false }); }); |
了解AngularJS $resource的更多相关文章
- Spring resource bundle多语言,单引号format异常
Spring resource bundle多语言,单引号format异常 前言 十一假期被通知出现大bug,然后发现是多语言翻译问题.法语中有很多单引号,单引号在format的时候出现无法匹配问题. ...
- Spring5:@Autowired注解、@Resource注解和@Service注解
什么是注解 传统的Spring做法是使用.xml文件来对bean进行注入或者是配置aop.事物,这么做有两个缺点: 1.如果所有的内容都配置在.xml文件中,那么.xml文件将会十分庞大:如果按需求分 ...
- 【初探Spring】------Spring IOC(三):初始化过程---Resource定位
我们知道Spring的IoC起到了一个容器的作用,其中装得都是各种各样的Bean.同时在我们刚刚开始学习Spring的时候都是通过xml文件来定义Bean,Spring会某种方式加载这些xml文件,然 ...
- 2000条你应知的WPF小姿势 基础篇<34-39 Unhandled Exceptions和Resource>
在正文开始之前需要介绍一个人:Sean Sexton. 来自明尼苏达双城的软件工程师.最为出色的是他维护了两个博客:2,000Things You Should Know About C# 和 2,0 ...
- 【解决方案】 org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userHandler': Injection of resource dependencies failed;
一个错误会浪费好多青春绳命 鉴于此,为了不让大家也走弯路,分享解决方案. [错误代码提示] StandardWrapper.Throwableorg.springframework.beans.fac ...
- AngularJS Resource:与 RESTful API 交互
REST(表征性状态传输,Representational State Transfer)是Roy Fielding博士在2000年他的博士论文中提出来的一种软件架构风格.RESTful风格的设计不仅 ...
- 运行nltk示例 Resource u'tokenizers punkt english.pickle' not found解决
nltk安装完毕后,编写如下示例程序并运行,报Resource u'tokenizers/punkt/english.pickle' not found错误 import nltk sentence ...
- Android LayoutInflater.inflate(int resource, ViewGroup root, boolean attachToRoot)的参数理解
方法inflate(int resource, ViewGroup root, boolean attachToRoot) 中 第一个参数传入布局的资源ID,生成fragment视图,第二个参数是视图 ...
- ORA-00054: resource busy and acquire with NOWAIT specified
删除表时遇到 ORA-00054:资源正忙,要求指定NOWAIT 错误.以前在灾备中心遇到过. 资源被锁定了,没有办法删除. 报错日志:ORA-00054: resource busy and acq ...
- angular学习笔记(二十八-附1)-$resource中的资源的方法
通过$resource获取到的资源,或者是通过$resource实例化的资源,资源本身就拥有了一些方法,$save,$delete,$remove,可以直接调用来保存该资源: 比如有一个$resour ...
随机推荐
- linux 输入子系统(1)----系统概述
输入设备的工作中,只是中断.读键值/坐标值是设备相关的,而输入事件的缓冲区管理以及字符设备驱动的file_operations接口则对输入设备是通用的,基于此,内核设计了input输入子系统,由核心层 ...
- linux乱码问题:LANG变量的秘诀
对于国内的Linux用户,经常烦恼的一个问题是:系统常常在需要显示中文的时候却显示成了乱码,而由于某些原因,需要英文界面的系统的时候,却苦于系统不能正常输入和显示中文.另外,由于大部分主要Linux发 ...
- 2016 Multi-University Training Contest 1 GCD RMQ+二分(预处理)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5726 题意:有N(N <= 100,000),之后有Q(Q <= 100,000)个区间查询[ ...
- PID控制器的数字实现及C语法讲解
PID控制器的数字实现及C语法讲解 概述 为方便学习与交流,根据自己的理解与经验写了这份教程,有错误之处请各位读者予以指出,具体包含以下三部分内容: (1) PID数字化的推导过程(实质:微积分的近 ...
- Mvc生命周期深度剖析
客户端发送请求->IIS, UrlRouting模块对比URL, 默认如果该URL能对应到实体文件则退出MVC管道把控制权交还给IIS. 如果RegisterRoutes中的路由规则对比成功默认 ...
- 中文变英文字母(ios)
[_EnglishName setString:addressPerson.name]; if (CFStringTransform((__bridge CFMutableStringRef)_Eng ...
- cocos2dx-Lua中出现的问题
1,在Lua中print输出失效的问题 在main.lua中添加print=release_print :
- 使用Docker解决同一服务器运行不同版本PHP方案。
前言: 最近公司有两个站点,分别是两种系统进行二次开发,基于LNMP架构的网站.一般想PHP这种非编译型语言想要对外出售源码都会进行加密,加密方法有很多种,大部分都是使用Zend Guard来进行加密 ...
- VS2008的默认打开重置为VS2008
- 防止IFRAME页被嵌套
防止IFRAME页被嵌套 //最大化窗口,防止窗口嵌套 if (parent.location != window.location){ parent.location = window.locati ...