Angular.js中$resource高大上的数据交互详解
本文主要给大家介绍的是关于Angular.js中$resource数据交互的相关内容,分享出来供大家参考学习,狼蚁网站SEO优化来一起看看详细的介绍
$resource
创建一个resource对象的工厂函数,可以让你安全的和RESFUL服务端进行数据交互。
需要注入 ngResource 模块。angular-resource[.min].js
默认情况下,末尾斜杠(可以引起后端服务器不期望出现的行为)将从计算后的URL中剥离。
这个可以通过$resourceProvider配置
app.config(["$resourceProvider",function($resourceProvider){ $resourceProvider.defaults.stripTrailingSlashes = false; }])
依赖$http
使用$resource(url,[paramDefaults],[actions],options);
url:一个参数化的url模板,带有前缀参数(如/user/:username)。如果你使用的是带端口号的URL(如http://example.:8080/api),则需要慎重考虑。如果带有后缀(如http://example./resource.json 或者 http://example./:id.json 或者 http://example./resource/:resource_id.:format) 。如果后缀之前的参数是空的,在这情况下:resource_id 比 /.优先执行,如果你需要这个序列出现而不崩溃,那么你可以通过/\.避免。
paramDefaults:url参数的默认值,这些可以在方法重写。如果参数的任何一个值是函数,它将作为每一次请求获取的参数值而被执行(除非该参数被忽略的)。
参数对象中的每个键值对都是先绑定到一个url模板,任何多余的密钥都被附加到url query的“?”后。 /path/:verb +{verb:'greet',salutation:'hello'} => /path/greet?salutation=hello
actions: 用户对于resource行为的默认设置进行扩展的自定义配置的散列,该配置将会以$http.config的格式创建。
action: 字符串,action的名称,这个名称将成为resource对象方法的名称。
method字符串,http方法(不区分大小写,如GET, POST, PUT, DELETE, JSONP等)。
params对象,这次行动预先设定的参数。如果任何参数的值是一个函数,当一个参数值每一次需要获得请求时都会被执行(除非该参数被忽略的)。
url字符串,行为指定的网址。
isArrayboolean,如果为true,那么这个行为返回的对象是个数组。
transformRequest函数/函数的数组。转换函数或者一个包含转换函数的数组。转换函数获取http请求体和请求头,并且返回他们的转换版(通常是序列化)。
transformResponse函数/函数的数组。转换函数或者一个包含转换函数的数组。转换函数获取http响应体和响应头,并且返回他们的转换版(通常是序列化)。
cacheboolean,如果为true,一个默认的$http缓存将被作为请求的缓存,否则如果存在一个用$cacheFactory创建的缓存实例,则将用于缓存。
timeout数值,毫秒,超时则让请求中止。
withCredentialsboolean,是否设置withcredentials flag的XHR对象。查看更多信息的凭据。
responseType字符串,响应头类型。
interceptor对象,拦截对象有两个可选方法-response和responseError。
Options扩展$resourceProvider行为的自定义设置,唯一支持的选项是stripTrailingSlashes,boolean类型,如果为真,url尾部的斜杠会被移除(默认为true)。
五种默认行为
{ “get”:{method:“get”}, “save”:{method:“post”} “query”:{method:“get”,isArray:true} “remove”:{method:“delete”} “delete”:{method:“delete”} } get([params],[suess],[error]); save([params],postData,[suess],[error]); query([params],[suess],[error]); remove([params],postData,[suess],[error]); delete([params],postData,[suess],[error]); $save([params],[suess],[error]); $remove([params],[suess],[error]);
使用代码
(function () { angular.module("Demo", ["ngResource"]) .controller("testCtrl", ["$resource",testCtrl]); function testCtrl($resource) { var myResource = $resource("/url/_url", {}, { myPost: { method: "post", url: "/newUrl/_newUrl", params: { id: "4" }, interceptor: { response: function (d) { console.log(d); }, responseError: function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 } } } }); myResource.get({ id: "1" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); myResource.query({ content: "text" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); myResource.save({ text: "Hello World" }, { text: "Hello World" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); myResource.remove({ text: "Hello World" }, { text: "Hello World" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); myResource.delete({ text: "Hello World" }, { text: "Hello World" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); var newResource = new myResource(); newResource.$save({ id: "2" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); newResource.$remove({ id: "3" }, function (d) { console.log(d); }, function (d) { console.log(d);//这里的是随便写的地址,所以执行了error里的函数,可打印看参数及结果 }); myResource.myPost(); }; }());
关于$resource,这里只是简单的介绍和使用,本兽对$resource的理解也不会很深(很少用到restful),希望有人交流相关问题。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对狼蚁SEO的支持
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程