Augular http服务

一: 在 app.moudel.ts 中导入 HttpClientModule 模块

import { HttpClientModule } from '@angular/common/http';

别忘记下边全局模块中添加 HttpClientModule

imports: [
    BrowserModule,
    FormsModule,
    HttpClientModule,//加入这个
    AppRoutingModule
  ],

二:在要创建的服务或组件中引入 HttpClient 模块

import { HttpClient } from '@angular/common/http';

并且在相应的构造函数中声明

export class HeaderComponent implements OnInit {
    //http 为变量名 自己定义的
  constructor(public http: HttpClient) { }

  ngOnInit() {
  }
}

三:设置请求方法

组件中使用写法

export class HeaderComponent implements OnInit {

  constructor(public http: HttpClient) { }

  ngOnInit() {
  }
  getD () {
     this.http.get('/api/po').subscribe(data => {
       // subscribe订阅方法,该方法可以获取异步返回的数据,也可以视作一个数据处理的回调函数
       console.log(data);
     });
  }
}

注意:get方法传入得参数为请求的url,如果是post方法需要传入第二个参数,第二个参数为提交数据,数据类型为对象

 

subscribe(data => { })  该小括号中是一个回调函数 data为返回数据   

在写小括号内的回调函数时,webstorm会自动在data前边添加 next:  ,   还有get方法的 参数前边添加 url:, 如果没有不用管,不要自己去手打,如果有不要管它

 

服务写法

在服务的 ts文件中写 get/post方法

export class HttpService {

  constructor(public http: HttpClient) { }
  getMyData() {
    return this.http.get('/api/get');
  }
//  设置post方法
  postMyData() {
    // post 第一个参数为请求接口,第二个参数为提交数据
    return this.http.post('/api/post', {
      name: '公孙离',
      age: 12
    });
  }

然后在组件中引入该服务

import { HttpService } from '../../service/http.service';

并且在构造函数中声名

constructor( public https: HttpService) { }

设置方法

 // 使用Http的get方法
  useHttpGet() {
    this.https.getMyData().subscribe(data => {
      console.log(data);
    });

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值