前言

 $resource详解,在学习angular的过程中,我们已经知道,$http能十分便捷的为我们实现与后端的数据交互,格式如下:

$http({method:'GET'},url:'XX').then(successFun,errorFcun)

 选好交互方式(method是GET或者POST),填好地址(url是你要交互的后台地址),然后在成功(successFun)以及失败(errorFun)回调函数中分别去处理反馈回来的数据,这个容易理解,直到遇到angular中另一种数据交互方式$resource时,我觉得有必要着重整理记下笔记了。

1.$resource是个啥,$resouce起步

$resource是angularjs提供的另一种数据交互方式,它其实一个$resourced对象集合体,这个集合体中包含了五类常用的交互方式,比如get,remove.....我们可以直接使用它们(后面详细说),与$http相比,它的交互方式其实更为灵活,我们除了可以使用它体现提供的方法API外,它更支持用户自定义交互方法。它不像$http在控制器controller中申明就可以直接使用,angular并未包含$resource服务,所以我们需要额外去引用它。例如,在引用angularjs后还需引用$resouce的js文件(目录根据自己情况来):

引用之后,我们还得在应用申明时去注入它,假设咱们有个app应用,如下:

var app = angular.module("myApp",["ngResource"])

这样,我们就可以在后续的开发中直接使用它而不报错了。

2. $resource对象与它包含的五类方法

2.1 理解$resource对象

假设,我们在网上一家百货店买了一些日用品到货了,由于你不在家,师傅给你丢在你楼下一家超市了,需要自己去自取,那现在最重要的,我们需要知道是楼下2家超市的哪一家(交互的后台url地址),去了超市,老板说你自己去那一堆快递里自己拿吧,我懒得管你,还好,快递在,然后我们取回了一个大箱子(一个$resource对象),箱子里是一些可以分别使用的工具,你只需要分别取使用它们就OK了。那么现在我们来看看$resouce对象的获取方法:

var url = "http://xxx/xxx/xxx"
app.controller("myCtrl",function($scope,$resource){
var Entry = $resource(url);
)}

其中,url就是咱们数据交互的地址,而Entry就是咱们拿到手的一大箱东西了,知道地方咱们直接去拿,拿回来怎么用那就是后话,问题不大,那现在我们拆箱好好使用箱子里面的这些东西。

2.2 $resource中的方法

2个get类型

1.get(params,successFn,errorFn)

2.query(params,successFn,errorFn)

3个非get类型

3.save(params,payload,successFn,errorFn)

4.remove(params,payload,successFn,errorFn)

5.delete(params,payload,successFn,errorFn)

那括号里面分别代表什么意思呢?

params:跟随请求一起发送的参数,比如,查询条件。

payload:跟随请求一起发送的数据体,比如把要存的数据。

successFn:请求成功函数,在这里咱们可以根据自己需求去处理返回的数据。

errorFn:失败函数,会返回包含status状态码等参数,咱们可以根据这个判断哪里出错了。

2.2.1 get()--查

首先说说get(),我们先看个例子:

//地址这里根据实际的来
var url = "http://xxx/xxx/xxx/:id";
//控制器中开始使用
app.controller("myCtrl",function($scope,$resource){
  //第一次取快递,把$resource对象存在Entry中了
var Entry = $resource(url);
  //第二次取快递,更详细的数据交互
Entry.get({
'id':
},function(resp){
    //处理成功函数
$scope.message = resp;
},function(err){
    //处理失败函数
console.log(err);
})
)}

咱们可以把这段代码理解为取两次快递

第一次取快递,咱们把$resouce对象保存在了Entry中

第二次取快递,咱们的又一个快递到了,还是丢在了那家超市,由于第一次咱们去过那家超市了就直接去取吧,不过这次老板就比较负责了,需要你提供下手机号码后四位数,那么我的尾数是3312(id:3312),于是老板就把3312的这个快递(这条数据)给我们了。于是咱们完成了第二次较为详细的http请求。

地址虽然没变,但是却多了一个对手机号码的流程,所以在上述代码url结尾有个":id",这个用处就是用来单一条件查询用的。

咱们之所以能直接使用Entry.get()就能获取到对应地址的数据,是因为Entry在赋值保存时已经包含了地址信息,所以get没必要再次提供地址。

2.2.2query():--查

Entry.query(function(messages) {
// 读取集合中第一条数据
$scope.message= messages[];
});

query也属于get请求,但与get相比,它更常用语获取大量数据的数组,而get更适合加上ID去获取某一条数据。

2.2.3save()--增

Entry.save({
"id": ,
"age": "",
"name": "小钻风",
},function(resp){
$scope.message = resp;
},function(err){
console.log(err);
})

存储一条包含id,age以及name属性的一条数据

save用于像后端存储一条新的数据,需要注意的是,当你想修改某条已经存在的数据时,不要想着找到对应id数据后利用save进行覆盖更新,这是会报错的,因为save本质是新增数据,并不能用于存储覆盖现有数据。

2.2.4delete()与remove()--删

Entry.remove({
'id':
},function(resp){
$scope.message = resp;
},function(err){
console.log(err);
})

找到id为10000的数据,并且删除掉这条数据

这对兄弟功能以及使用完全一样,那为啥要存在2个呢,那是因为delete是JS的保留字,在IE中使用会存在其它报错问题,所以保险起见,还是直接用remove进行删除吧。

3.$resource中的自定义方法

我们在前面说了增删查,那我们要改已经存在库里面的数据咋办,而且也说了,save只能新增,并不能修改,那这时候就得自定义一个修改的方法了。

其实在获取$resource对象时,除了单一提供url参数外,其实还有其他的可选参数,我们看看如何定义一个修改:

 var Entry = $resource(url,{},{
update:{
method:'PUT'
}
});
  Entry.update({
    'id':10000
  },{
    "id": 10000,
    "age": "28",
    "name": "小钻风",
  },function(resp){
    $scope.message = resp;
  },function(err){
    console.log(err);
  })
 

上述代码分为两步,第一,获取$resource对象,同时封装了一个update的方法,第二部,使用update找到id为10000的数据,将其覆盖为我们后面提供的数据。

这里我们定义的method为put,简单提下PUT: 把消息本体中的消息发送到一个URL,通常用于向服务器发送请求,如果URI不存在,则要求服务器根据请求创建资源,如果存在,服务器就接受请求内容,并修改URI资源的原始版本。

update是我们自定义的方法名,你想取啥就取啥,当然在使用时你得跟你上面定义的一样,在update中其实还可以定义更多属性,如下:

$resource(url,{},{
update:{
method:'', //送HTTP请求的方法
url:'', //为该方法的具体路由设置的URL
params:{},
isArray:boolean, //为ture此动作返回数组
transformRequest:函数或者函数数组
transformResponse:函数或者函数数组
cache:布尔型或缓存对象
timeout:数值或promise对象
withCredentials:布尔类型
responseType:字符串,用来设置XMLHttpRequestResponseType属性
}
})

先整理到这吧。

白话$resource,$resource中的增删改查的更多相关文章

  1. 【设计模式】【应用】使用模板方法设计模式、策略模式 处理DAO中的增删改查

    原文:使用模板方法设计模式.策略模式 处理DAO中的增删改查 关于模板模式和策略模式参考前面的文章. 分析 在dao中,我们经常要做增删改查操作,如果每个对每个业务对象的操作都写一遍,代码量非常庞大. ...

  2. winform窗体(六)——DataGridView控件及通过此控件中实现增删改查

    DataGridView:显示数据表,通过此控件中可以实现连接数据库,实现数据的增删改查 一.后台数据绑定:    List<xxx> list = new List<xxx> ...

  3. Winform(DataGridView)控件及通过此控件中实现增删改查

    DataGridView:显示数据表,通过此控件中可以实现连接数据库,实现数据的增删改查 一.后台数据绑定:    List<xxx> list = new List<xxx> ...

  4. DataGridView中进行增删改查

    首先我们需要知道是在哪个数据库中的哪个表进行增删改查: 这就需要我们: 建立给连接服务器的类:(可以在方法类中建立) 建立一个对列名进行封装的类:方便数据之间的传接:(学到Linq-sql时这些就简便 ...

  5. mybatis中的增删改查操作

    在这一个部分,主要进行增删改查的示例书写. 增删改查可以基于xml的,也可以基于注解的方式. 一:对单条数据的查询 1.目录结构 这个使得目录更加清晰 2.User.java 这个使用以前的user表 ...

  6. SQLite中的增删改查

    虽然android提供了sql查询的封装方法,但是理解起来还是麻烦,所以我这里用sql语句来完成工作. 首先是建立一个类,继承SQLiteOpenHelper 这里面会建立一个数据库,并且初始化一个表 ...

  7. “造轮运动”之 ORM框架系列(一)~谈谈我在实际业务中的增删改查

    想想毕业已经快一年了,也就是大约两年以前,怀着满腔的热血正式跨入程序员的世界,那时候的自己想象着所热爱的技术生涯会是多么的丰富多彩,每天可以与大佬们坐在一起讨论解决各种牛逼的技术问题,喝着咖啡,翘着二 ...

  8. (转)MySql中监视增删改查和查看日志记录

    转载地址为:http://blog.51cto.com/hades02/1641652 首先在命令行输入 show global variables like '%general%' ,然后出现下面的 ...

  9. SQL数据库中的增删改查总结1

    一.增:有2种方法 1.使用insert插入单行数据: 语法:insert [into]<表名> [列名] values <列值> 例:insert into Strdents ...

随机推荐

  1. 《principal component analysis based cataract grading and classification》学习笔记

    Abstract A cataract is lens opacification caused by protein denaturation which leads to a decrease i ...

  2. 笔记1:jmeter性能测试使用示例(原文:http://blog.csdn.net/zhongweijian/article/details/7619319)

    jmeter是一个简单开源的纯java的性能测试工具.今天学习了jmeter使用了下jmeter,使用起来非常简单. 如果我们要对163的首页性能进行简单测试,我们可以按照以下步骤进行. 1.在测试计 ...

  3. Delphi 在DLL中使用DevExpress控件时出错解决办法

    测试环境 DevExpress VCL 14.1.3 和XE7 问题:在dll使用cxGrid控件时  如果不添加列标题 则不报错   查询无数据集显示,如果加上标题 就报错了 这段为报错部分 fun ...

  4. cxGrid之checkbox小结

    http://www.cnblogs.com/Kim53622744/p/4428997.html 在cxgrid中增加选择列 1.在dataset(query/table/clientdataset ...

  5. delphi 分享三个随机字符串

    uses math; function GenID:String; var b, x: byte; begin Result := '{'; Randomize; do begin ) > ,) ...

  6. ZOJ 1259 Rails

    stack的应用 #include<iostream> #include<cstdio> #include<stack> using namespace std; ...

  7. Windows远程桌面连接ubuntu 16

    一.安装Xrdp Windows远程桌面使用的是RDP协议,所以ubuntu上就要先安装Xrdp,在ubuntu软件中心搜索xrdp安装. 安装xrdp的同时会自动安装vnc4server,xbase ...

  8. play framework - 初识

    背景 研发代码框架是play-framework框架,想看代码的话,需要学习下play框架.IDE工具的话之前一直用的idea,所以本文涉及的idea play的配置 和 一些play的简单知识 认识 ...

  9. ASP.Net MVC OA项目笔记<四>

    1.1.1 EF线程唯一 在数据层中用到了EF的实例,在数据会话层也用到了,所以在一个请求中只能创建一个EF实例(线程内唯一对象),把它封装成工厂类 1.1.2 为了防止相互引用,循环引用,所以这个工 ...

  10. 使用EF6连接mariaDB出现中文查找不到数据的问题

    1.问题描述 这两天使用ef6.0查询mariaDB出现了数据查询不到的情况 2.问题分析 后来发现除了这段数据查询不到,其他都能查询,于是逐步对比代码,发现其他数据都是英文的,而这句是中文的于是把条 ...