详解AngularJS2 Http服务

发布时间 - 2026-01-11 02:03:45    点击率:

关于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; }
   });
}

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

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


# Angular2  # Http服务  # Http  # 详解为Angular.js内置$http服务添加拦截器的方法  # AngularJS中$http服务常用的应用及参数  # 简介AngularJS中$http服务的用法  # 自定义  # 要在  # 就可以  # 组中  # 这步  # 是在  # 会有  # 是因为  # 中有  # 只需  # 会在  # 它是  # 他会  # 说明了  # 错误信息  # 信息查询  # 回调  # 大家多多  # 转化成  # 情况下 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: js实现获取鼠标当前的位置  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  如何挑选高效建站主机与优质域名?  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  Laravel如何配置Horizon来管理队列?(安装和使用)  深入理解Android中的xmlns:tools属性  js实现点击每个li节点,都弹出其文本值及修改  Python数据仓库与ETL构建实战_Airflow调度流程详解  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  Android okhttputils现在进度显示实例代码  如何在云主机快速搭建网站站点?  实例解析Array和String方法  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  详解jQuery停止动画——stop()方法的使用  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  Laravel怎么发送邮件_Laravel Mail类SMTP配置教程  EditPlus中的正则表达式 实战(1)  Laravel Fortify是什么,和Jetstream有什么关系  微信公众帐号开发教程之图文消息全攻略  如何在Ubuntu系统下快速搭建WordPress个人网站?  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  Laravel如何配置和使用缓存?(Redis代码示例)  焦点电影公司作品,电影焦点结局是什么?  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  如何快速使用云服务器搭建个人网站?  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  如何在万网利用已有域名快速建站?  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  javascript日期怎么处理_如何格式化输出  Laravel如何实现数据库事务?(DB Facade示例)  如何破解联通资金短缺导致的基站建设难题?  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  企业网站制作这些问题要关注  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  长沙做网站要多少钱,长沙国安网络怎么样?  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  如何在云主机上快速搭建多站点网站?  微信小程序 闭包写法详细介绍  微信小程序 input输入框控件详解及实例(多种示例)  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  如何在万网自助建站中设置域名及备案?