angualrs4 http请求

配置后端服务器地址

node搭建简单的web服务器:http://www.cnblogs.com/Caiyilong/p/8676693.html

在根目录创建proxy.conf.json文件,配置服务器接口,后台访问地址:http://localhost:8000/api/products

{
    "/api":{
        "target":"http://localhost:8000"
    }
}

修改package.json中的启动命令:启动时使用命令$ npm run start

"start": "ng serve",
//改为
"start": "ng serve --proxy-config proxy.conf.json",

前端代码

product.component.html

<div>
  商品信息
</div>
<ul>
  <li *ngFor="let product of products">
    {{product.title}}
  </li>
</ul>

product.component.ts

import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs/Observable';
import { Http } from '@angular/http';
import 'rxjs/Rx';

@Component({
  selector: 'app-product',
  templateUrl: './product.component.html',
  styleUrls: ['./product.component.css']
})
export class ProductComponent implements OnInit {

  //定义一个流
  dataSource:Observable<any>;
  products:Array<any> = [];

  constructor(private http:Http) {
    //get请求,返回json类型的流
    this.dataSource = this.http.get("/api/products")
      .map((res) => res.json());
   }

  ngOnInit() {
    this.dataSource.subscribe(
      (data) => this.products = data
    )
  }
}

使用async管道:

product.component.html

<div>
  商品信息
</div>
<ul>
  <li *ngFor="let product of products | async">
    {{product.title}}
  </li>
</ul>

product.component.ts

import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs/Observable';
import { Http } from '@angular/http';
import 'rxjs/Rx';

@Component({
  selector: 'app-product',
  templateUrl: './product.component.html',
  styleUrls: ['./product.component.css']
})
export class ProductComponent implements OnInit {

  //使用async管道
  products:Observable<any>;

  constructor(private http:Http) {
    //get请求,返回json类型的流
    this.products = this.http.get("/api/products")
      .map((res) => res.json());
   }

  ngOnInit() {}
}

 

转载于:https://www.cnblogs.com/Caiyilong/p/8677790.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值