详解AngularJS2 Http服务


Posted in Javascript onJune 26, 2017

关于http服务

HttpModule并不是angular的核心模块,它是一个附加的模块,存在于@angular/http中,虽然如此但是依然可以在需要的时候使用它,只需要在使用之前引入即可。对于大多数app来说使用http服务是很常见的,所以我们将HttpModule加入到AppModule的import列表和应用的根组件中,这样就可以在整个应用中使用http服务了

在自定义服务中使用Http服务

http服务通过其get方法获取数据,他会返回RxJS Observable,我们希望使用的数据是Promise,然而 Observable 并没有toPromise()方法,可以在自定义服务中这样引入

import 'rxjs/add/operator/toPromise';

如此就拓展了Observable的功能了

具体代码如下

import { Injectable }  from '@angular/core';

import { Headers, Http } from '@angular/http';

import 'rxjs/add/operator/toPromise';

import { Hero } from './hero';
 private heroesUrl = 'api/heroes'; // URL to web api

 constructor(private http: Http) { }

 getHeroes(): Promise<Hero[]> {
  return this.http.get(this.heroesUrl)
        .toPromise()
        .then(response => response.json().data as Hero[])
        .catch(this.handleError);
 }

 private handleError(error: any): Promise<any> {
  console.error('An error occurred', error); // for demo purposes only
  return Promise.reject(error.message || error);
 }

在回调函数then()中调用了返回对象的json()方法将data从返回对象中分离出来

.then(response => response.json().data as Hero[])

 这里的.data是因为返回对象中有data这个属性,具体情况下会不一样

注意:Http failure是经常发生的,必须预料到会有异常的可能,所以在方法最后捕获了异常并将其传递给异常处理器,使用Promise.reject()将错误信息返回给服务调用者

利用服务实现数据的增删改查

信息查询

可以在请求url里面带上参数,这样就可以将参数传到后台,服务器查到信息后返回到前台

getHero(id: number): Promise<Hero> {
    const url = `${this.heroesUrl}/${id}`;
    return this.http.get(url).toPromise()
   .then(response => response.json().data as Hero)
   .catch(this.handleError);
  }

修改信息

在自定义服务中

private headers = new Headers({'Content-Type': 'application/json'});
  update(hero: Hero): Promise<Hero> {
  const url = `${this.heroesUrl}/${hero.id}`;
  return this.http
  .put(url, JSON.stringify(hero), {headers: this.headers})
  .toPromise()
  .then(() => hero)
  .catch(this.handleError);
}

依然是在url后带上id告知服务器要修改的记录标识,JSON.stringify()将对象转化成json字符串,通过put将字符串放到请求中,header说明了请求体的类型

在调用服务的组件中

save(): void {
   this.heroService.update(this.hero)
    .then(() => this.goBack());
  }

修改成功后返回前一个视图

添加信息

在自定义服务中

create(name: string): Promise<Hero> {
 return this.http
  .post(this.heroesUrl, JSON.stringify({name: name}), {headers: this.headers})
  .toPromise()
  .then(res => res.json().data)
  .catch(this.handleError);
}

删除信息

在自定义服务中

delete(id: number): Promise<void> {
   const url = `${this.heroesUrl}/${id}`;
   return this.http.delete(url, {headers: this.headers})
    .toPromise()
    .then(() => null)
    .catch(this.handleError);
  }

这步只是将后台的信息删除了,但是本地数组中依然存在,所以依然会在视图中显示,所以就要在组建中进行一些处理

delete(hero: Hero): void {
 this.heroService
   .delete(hero.id)
   .then(() => {
    this.heroes = this.heroes.filter(h => h !== hero);
    if (this.selectedHero === hero) { this.selectedHero = null; }
   });
}

这步就是将已经删除的数据从本地数组中过滤掉

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
textarea的value是html文件源代码,存成html文件的代码
Apr 20 Javascript
jsp+javascript打造级连菜单的实例代码
Jun 14 Javascript
jquery ajax的success回调函数中实现按钮置灰倒计时
Nov 19 Javascript
jQuery模拟点击A标记示例参考
Apr 17 Javascript
在JS中操作时间之getUTCMilliseconds()方法的使用
Jun 10 Javascript
switch语句的妙用(必看篇)
Oct 03 Javascript
AngularJS 使用ng-repeat报错 [ngRepeat:dupes]
Jan 19 Javascript
validationEngine 表单验证插件使用实例代码
Jun 15 Javascript
基于node.js之调试器详解
Aug 22 Javascript
微信小程序实现联动选择器
Feb 15 Javascript
jsonp实现百度下拉框功能的方法分析
May 10 Javascript
vue实现的多页面项目如何优化打包的步骤详解
Jul 19 Javascript
详解用node.js实现简单的反向代理
Jun 26 #Javascript
JS作用域链详解
Jun 26 #Javascript
jQuery.Form实现Ajax上传文件同时设置headers的方法
Jun 26 #jQuery
纯JS实现简单的日历
Jun 26 #Javascript
vue2.0全局组件之pdf详解
Jun 26 #Javascript
JavaScript创建对象的七种方式(推荐)
Jun 26 #Javascript
基于 webpack2 实现的多入口项目脚手架详解
Jun 26 #Javascript
You might like
php引用计数器进行垃圾收集机制介绍
2012/09/19 PHP
wamp下修改mysql访问密码的解决方法
2013/05/07 PHP
php 过滤英文标点符号及过滤中文标点符号代码
2014/06/12 PHP
php中Socket创建与监听实现方法
2015/01/05 PHP
php判断邮箱地址是否存在的方法
2016/02/13 PHP
thinkPHP5项目中实现QQ第三方登录功能
2017/10/20 PHP
摘自百度的图片轮换效果代码
2007/11/19 Javascript
JS Excel读取和写入操作(模板操作)实现代码
2010/04/11 Javascript
JQuery EasyUI 对话框的使用方法
2010/10/24 Javascript
js 高效去除数组重复元素示例代码
2013/12/19 Javascript
jQuery中find()方法用法实例
2015/01/07 Javascript
JavaScript中的Repaint和Reflow用法详解
2015/07/27 Javascript
基于javascript制作经典传统的拼图游戏
2016/03/22 Javascript
Bootstrap每天必学之弹出框(Popover)插件
2016/04/25 Javascript
JS iFrame加载慢怎么解决
2016/05/13 Javascript
AngularJS 模块详解及简单实例
2016/07/28 Javascript
Vue.js实现无限加载与分页功能开发
2016/11/03 Javascript
详解Chai.js断言库API中文文档
2018/01/31 Javascript
JS实现匀速与减速缓慢运动的动画效果封装示例
2018/08/27 Javascript
使用python将mdb数据库文件导入postgresql数据库示例
2014/02/17 Python
Python中下划线的使用方法
2015/03/27 Python
Python解析nginx日志文件
2015/05/11 Python
请不要重复犯我在学习Python和Linux系统上的错误
2016/12/12 Python
详解python中requirements.txt的一切
2017/03/03 Python
Python DataFrame.groupby()聚合函数,分组级运算
2018/09/18 Python
从运行效率与开发效率比较Python和C++
2018/12/14 Python
python 多进程和协程配合使用写入数据
2020/10/30 Python
Bibloo荷兰:女士、男士和儿童的服装、鞋子和配饰
2019/02/25 全球购物
区域总监的岗位职责
2013/11/21 职场文书
国家助学金获奖感言
2014/01/31 职场文书
大学校运会广播稿
2014/02/03 职场文书
模具设计与制造专业推荐信
2014/02/16 职场文书
环境监测与治理技术专业求职信
2014/07/06 职场文书
工作收入证明模板
2014/10/10 职场文书
课外活动实习计划
2015/01/19 职场文书
阿里云国际版 使用Nginx作为HTTPS转发代理服务器
2022/05/11 Servers