博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Angular 2 HTTP Requests with Promise
阅读量:6234 次
发布时间:2019-06-21

本文共 2621 字,大约阅读时间需要 8 分钟。

第一步:模拟restful api,还是以英雄列表为例。(我用的是node+express模拟,禁用同源策略)没什么好说的直接上代码。

var express = require('express');

var app = express();

//设置跨域访问式一 

app.all('*', function (req, res, next) {

res.header("Access-Control-Allow-Origin", "*");

res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");

res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");

res.header("X-Powered-By", ' 3.2.1')

res.header("Content-Type", "application/json;charset=utf-8");

next();

});

app.get('/heroes', function (req, res) {

//res.header("Access-Control-Allow-Origin", "*");   //设置跨域访问方式二

var ret_obj = [{ "id": 1, "name": "Jackie Chan" }, { "id": 2, "name": "Jet Li" }];

res.end(JSON.stringify(ret_obj));

})

var server = app.listen(8081, function () {

var host = server.address().address

var port = server.address().port

console.log("应用实例,访问地址为ַ:http://%s:%s", host, port)

})

chrome中测试下,结果见下图。

第二步:定义英雄结构(hero.ts)

export class Hero {

   id: number;

   name: string;

   constructor(_id: number, _name: string) {

      this.id = _id;

      this.name = _name;

  }

}

第三步:编写英雄服务(hero.service.ts)

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

import { Http } from "@angular/http";

import 'rxjs/add/operator/catch';

import 'rxjs/add/operator/toPromise';

import { Hero } from './hero'

@Injectable()

export class HeroService {

heroesUrl = "http://localhost:8081/heroes";

constructor(private http: Http) { }

GetHeores(): Promise<Hero[]> {

return this.http.get(this.heroesUrl)

            .toPromise()

            .then(response => { console.log("Get the heroes from the server side succeeded!"); return response.json() 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);

    }

}

第四步:组件调用(hero.service.ts)

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

import { Hero } from './hero'

import { HeroService } from './hero.service'

@Component({

selector: 'app-root',

templateUrl: './app.component.html',

styleUrls: ['./app.component.css'],

providers: [HeroService]

})

export class AppComponent {

title = 'Tour of Heroes';

heroes: Hero[];

selectedHero: Hero;

constructor(private heroService: HeroService) { }

getHeroes(): void {

this.heroService

      .GetHeores()

      .then(heroes => { this.heroes = heroes; console.log(heroes) });

  }

ngOnInit(): void {

this.getHeroes();

  }

}

模板文件(app.component.html)如下:

<h1>{

{title}}</h1>

<h2>My Heroes</h2>

<ul class="heroes">

<li *ngFor="let hero of heroes">

<span class="badge">{

{hero.id}}</span> {
{hero.name}}

</li>

</ul>

第五步:chrome中的运行效果:

转载于:https://www.cnblogs.com/rfyuanwei/p/6638930.html

你可能感兴趣的文章
04文件操作1
查看>>
Asp.net mvc 3 - JSONResult return array
查看>>
Spring MVC - log4j 配置
查看>>
c# WF 第6节 MDI窗体
查看>>
杂七杂八
查看>>
RabbitMQ 消息确认机制
查看>>
简单的新浪微博OAuth认证实现
查看>>
Mybatis表关联一对多
查看>>
Spring_Aop基于配置文件
查看>>
R cannot be resolved的几种可能 R not generated
查看>>
随机快速排序
查看>>
linux下创建用户、用户组及赋予sudoer权限
查看>>
简述Hibernate配置连接池
查看>>
路径1
查看>>
poj 2492 A Bug's Life (并查集)
查看>>
自定义Loader
查看>>
IOS 给UILabel字体加一个带颜色的边框
查看>>
查看电脑硬件信息dos命令
查看>>
2010年Java高新技术A(5)类加载器和代理
查看>>
每天学点GDB 10
查看>>