详解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 相关文章推荐
jQuery 计算iframe 窗口大小的方法
May 13 Javascript
javascript常用函数(1)
Nov 04 Javascript
实现JavaScript的组成----BOM和DOM详解
May 18 Javascript
jquery 实现滚动条下拉时无限加载的简单实例
Jun 01 Javascript
html+js+highcharts绘制圆饼图表的简单实例
Aug 04 Javascript
Node.js包管理器Yarn的入门介绍与安装
Oct 17 Javascript
基于Vue的文字跑马灯组件(npm 组件包)
May 24 Javascript
jQuery实现判断上传图片类型和大小的方法示例
Apr 11 jQuery
vue.js使用3DES加密的方法示例
May 18 Javascript
利用weixin-java-miniapp生成小程序码并直接返回图片文件流的方法
Mar 29 Javascript
Js图片点击切换轮播实现代码
Jul 27 Javascript
javascript中导出与导入实现模块化管理教程
Dec 03 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中的session永不过期的解决思路及实现方法分享
2011/04/20 PHP
Eclipse中php插件安装及Xdebug配置的使用详解
2013/04/25 PHP
PHP简单检测网址是否能够正常打开的方法
2016/09/04 PHP
利用php操作memcache缓存的基础方法示例
2017/08/02 PHP
PHP底层运行机制与工作原理详解
2020/07/31 PHP
JavaScript 加号(+)运算符号
2009/12/06 Javascript
jQuery中setTimeout的几种使用方法小结
2013/04/07 Javascript
Jquery解析json数据详解
2013/12/26 Javascript
JavaScript中使用stopPropagation函数停止事件传播例子
2014/08/27 Javascript
Node.js实现在目录中查找某个字符串及所在文件
2014/09/03 Javascript
jquery动感漂浮导航菜单代码分享
2020/04/15 Javascript
利用JS实现数字增长
2016/07/28 Javascript
jQuery简单获取DIV和A标签元素位置的方法
2017/02/07 Javascript
JavaScript 数据类型详解
2017/03/13 Javascript
基于vue的fullpage.js单页滚动插件
2017/03/20 Javascript
Element-ui tree组件自定义节点使用方法代码详解
2018/09/17 Javascript
微信小程序仿知乎实现评论留言功能
2018/11/28 Javascript
jQuery选择器之层次选择器用法实例分析
2019/02/19 jQuery
node.js 微信开发之定时获取access_token
2020/02/07 Javascript
js实现幻灯片轮播图
2020/08/14 Javascript
JavaScript 闭包的使用场景
2020/09/17 Javascript
[03:38]2014DOTA2西雅图国际邀请赛 VG战队巡礼
2014/07/07 DOTA
python自动翻译实现方法
2016/05/28 Python
Python使用PyCrypto实现AES加密功能示例
2017/05/22 Python
Python实现字符串格式化输出的方法详解
2017/09/20 Python
python中使用正则表达式的后向搜索肯定模式(推荐)
2017/11/11 Python
python和shell获取文本内容的方法
2018/06/05 Python
Python OpenCV处理图像之滤镜和图像运算
2018/07/10 Python
python使用epoll实现服务端的方法
2018/10/16 Python
Python3 实现文件批量重命名示例代码
2019/06/03 Python
详解Python GUI编程之PyQt5入门到实战
2020/12/10 Python
html5使用Canvas绘图的使用方法
2017/11/21 HTML / CSS
五年后的职业生涯规划
2014/03/04 职场文书
2014年涉外离婚协议书范本
2014/11/20 职场文书
Redis5之后版本的高可用集群搭建的实现
2021/04/27 Redis
使用canvas仿Echarts实现金字塔图的实例代码
2021/11/11 HTML / CSS