全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解AngularJS2 Http服务

关于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服务的用法  # 自定义  # 要在  # 就可以  # 组中  # 这步  # 是在  # 会有  # 是因为  # 中有  # 只需  # 会在  # 它是  # 他会  # 说明了  # 错误信息  # 信息查询  # 回调  # 大家多多  # 转化成  # 情况下 


相关文章: c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  广州美橙建站如何快速搭建多端合一网站?  Python如何创建带属性的XML节点  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  如何制作网站标识牌,动态网站如何制作(教程)?  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  XML的“混合内容”是什么 怎么用DTD或XSD定义  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  ,交易猫的商品怎么发布到网站上去?  ,怎么用自己头像做动态表情包?  Python多线程使用规范_线程安全解析【教程】  制作电商网页,电商供应链怎么做?  北京制作网站的公司,北京铁路集团官方网站?  Java解压缩zip - 解压缩多个文件或文件夹实例  如何做网站制作流程,*游戏网站怎么搭建?  宁波自助建站系统如何快速打造专业企业网站?  建站上市公司网站建设方案与SEO优化服务定制指南  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  制作网页的网站有哪些,电脑上怎么做网页?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  网站制作壁纸教程视频,电脑壁纸网站?  如何在云虚拟主机上快速搭建个人网站?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  建站主机选择指南:服务器配置与SEO优化实战技巧  黑客入侵网站服务器的常见手法有哪些?  如何在云主机快速搭建网站站点?  浅谈Javascript中的Label语句  教程网站设计制作软件,怎么创建自己的一个网站?  python的本地网站制作,如何创建本地站点?  如何在Windows 2008云服务器安全搭建网站?  营销式网站制作方案,销售哪个网站招聘效果最好?  宝塔Windows建站如何避免显示默认IIS页面?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  如何批量查询域名的建站时间记录?  如何设计高效校园网站?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  网站代码制作软件有哪些,如何生成自己网站的代码?  如何在腾讯云服务器快速搭建个人网站?  高防服务器:AI智能防御DDoS攻击与数据安全保障  临沂网站制作公司有哪些,临沂第四中学官网?  电商网站制作价格怎么算,网上拍卖流程以及规则?  如何快速启动建站代理加盟业务?  广东企业建站网站优化与SEO营销核心策略指南  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  如何在宝塔面板中修改默认建站目录?  如何使用Golang table-driven基准测试_多组数据测量函数效率  零服务器AI建站解决方案:快速部署与云端平台低成本实践 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。