详解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 相关文章推荐
js字符编码函数区别分析
Dec 28 Javascript
浅析js预加载/延迟加载
Sep 25 Javascript
JavaScript中document.forms[0]与getElementByName区别
Jan 21 Javascript
jQuery+PHP实现动态数字展示特效
Mar 14 Javascript
javascript实时显示当天日期的方法
May 20 Javascript
js正则表达式验证邮件地址
Nov 12 Javascript
jQuery焦点图插件SaySlide
Dec 21 Javascript
js调用屏幕宽度的简单方法
Nov 14 Javascript
easyui combotree加载静态数据问题(选不上)解决方法
Dec 26 Javascript
深入理解vue中的$set
Jun 01 Javascript
React传值 组件传值 之间的关系详解
Aug 26 Javascript
antd-日历组件,前后禁止选择,只能选中间一部分的实例
Oct 29 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中文乱码
2009/11/26 PHP
使用PHP生成二维码的两种方法(带logo图像)
2014/03/14 PHP
destoon之一键登录设置
2014/06/21 PHP
php中的观察者模式简单实例
2015/01/20 PHP
PHP使用http_build_query()构造URL字符串的方法
2016/04/02 PHP
thinkPHP订单数字提醒功能的实现方法
2016/12/01 PHP
js判断变量是否空值的代码
2008/10/26 Javascript
javascript编码的几个方法详细介绍
2013/01/06 Javascript
escape函数解决js中ajax传递中文出现乱码问题
2014/10/30 Javascript
JS实现动态给图片添加边框的方法
2015/04/01 Javascript
javascript实现Table排序的方法
2015/05/15 Javascript
JavaScript与jQuery实现的闪烁输入效果
2016/02/18 Javascript
WordPress 单页面上一页下一页的实现方法【附代码】
2016/03/10 Javascript
angularjs下拉框空白的解决办法
2017/06/20 Javascript
ES6 对象的新功能与解构赋值介绍
2019/02/05 Javascript
微信小程序访问豆瓣电影api的实现方法
2019/03/31 Javascript
vue router 用户登陆功能的实例代码
2019/04/24 Javascript
关于ligerui子页面关闭后,父页面刷新,重新加载的方法
2019/09/27 Javascript
借助云开发实现小程序短信验证码的发送
2020/01/06 Javascript
python中异常捕获方法详解
2017/03/03 Python
Python网络爬虫中的同步与异步示例详解
2018/02/03 Python
pymongo中聚合查询的使用方法
2019/03/22 Python
python绘制多个子图的实例
2019/07/07 Python
python正则爬取某段子网站前20页段子(request库)过程解析
2019/08/10 Python
关于Python解包知识点总结
2020/05/05 Python
python的reverse函数翻转结果为None的问题
2020/05/11 Python
python编写softmax函数、交叉熵函数实例
2020/06/11 Python
python属于解释型语言么
2020/06/15 Python
windows系统Tensorflow2.x简单安装记录(图文)
2021/01/18 Python
python实现计算图形面积
2021/02/22 Python
CSS3实现3D翻书效果
2016/06/20 HTML / CSS
新西兰床上用品和家居用品购物网站:Adairs
2018/04/27 全球购物
NULL是什么,它是怎么定义的
2015/05/09 面试题
《小池塘》教学反思
2014/02/28 职场文书
2015年仓库工作总结
2015/04/09 职场文书
十大最强火系宝可梦,喷火龙上榜,第一名有双火属性
2022/03/18 日漫