HTTP 请求服务端数据

client端1、引入HttpClientModule模板import { BrowserModule } from '@angular/platform-browser';import { NgModule } from '@angular/core';import { AppRoutingModule } from './app-routing.module';import { AppComponent } from './app.component';import { Produc
摘要由CSDN通过智能技术生成

client端

1、引入HttpClientModule模板

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';

import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import { ProductComponent } from './product/product.component';
import {HttpClientModule} from '@angular/common/http';

@NgModule({
  declarations: [
    AppComponent,
    ProductComponent
  ],
  imports: [
    BrowserModule,
    AppRoutingModule,
    HttpClientModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

2. 编写客户端程序

product TS

import { Component, OnInit } from '@angular/core';
import {Subscription} from 'rxjs';
import {HttpClient} from '@angular/common/http';

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

  dataSource: Subscription;

  products: any;

  constructor(private http: HttpClient) {
  }

  ngOnInit(): void {
    this.http.get('/api/products').subscribe((data) => this.products = data);
    // this.http.request('get', '/api/products' );
  }
}

3.product HTML

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

服务器端

准备数据

import * as express from 'express';

const app = express();
const server = app.listen(8000,"localhost",()=>{
    console.log("服务已启动!!!");
});

app.get('/',(req, res) => {
    res.send("Hello Express!!");
});

app.get('/api/products', (req, res) => {
    res.json(products);
});

app.get('/api/product/:id', (req, res) => {
    //res.json(req.params);
    res.json(products.find((product) => (product.id.toString() == req.params.id)));
});

export  class Product {
    constructor(
        public id: number,
        public title: string,
        public price: number,
        public rating: number,
        public desc: string,
        public categories: Array<string>
    ) {
    }
}
const products: Product[] = [
    new Product(1, '大碗茶1', 1.99, 1.1, '这是一个值得买的藏品1', ['瓷器1', '明清代1']),
    new Product(2, '大碗茶2', 2.99, 2.2, '这是一个值得买的藏品2', ['瓷器3', '明清代2']),
    new Product(3, '大碗茶3', 3.99, 3.3, '这是一个值得买的藏品3', ['瓷器2']),
    new Product(4, '大碗茶4', 4.99, 4.4, '这是一个值得买的藏品4', ['瓷器1', '明清代1']),
    new Product(5, '大碗茶5', 5.99, 5.5, '这是一个值得买的藏品5', ['瓷器2']),
    new Product(6, '大碗茶6', 6.99, 6.6, '这是一个值得买的藏品6', ['瓷器3', '明清代3'])
];

client端配置提交的服务器路径

1、新建配置文件proxy.conf.json,告诉访问服务的目标地址以及前缀

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

2.把该配置添加到启动服务中

package.json中“start”参数,改为如下:

"start": "ng serve --proxy-config proxy.conf.json",
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值