This time I will show you how to operate Angular to implement data requests, and what are the precautions for operating Angular to implement data requests. The following is a practical case, let's take a look.
When using Angular to request data, you need to introduce the HttpModule module. If you use the jsonp mode, you need to introduce the JsonpModule module
import { HttpModule, JsonpModule } from '@angular/http'
imports: [ HttpModule, JsonpModule ],
import { Http, Jsonp } from '@angular/http'
constructor of the current component After injecting it, you can use it
constructor(private http: Http, private jsonp: Jsonp) { }
// 进行注入,拿到相对应的方法 constructor(private http: Http, private jsonp: Jsonp) { } public list: any = [] // 请求数据 getData() { let url = 'http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1' let _this = this this.http.get(url).subscribe((data) => { _this.list = JSON.parse(data['_body'])['result'] console.log(_this.list) }) }
<button (click)="getData()">get 请求数据</button> <ul> <li *ngFor="let item of list"> {{item.title}} </li> </ul>
JSONP request Data
Pay attention to the difference from the get request, use the following// 请求数据 jsonpData() { let url = 'http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1&callback=JSONP_CALLBACK' let _this = this this.jsonp.get(url).subscribe((data) => { _this.list = data['_body']['result'] console.log(_this.list) }) }
// 渲染 <button (click)="jsonpData()">jsonp 请求数据</button> <ul> <li *ngFor="let item of list"> {{item.title}} </li> </ul>
Name&callback=JSONP_CALLBACKThe request method changes to this.jsonp.get(url)
The data format obtained after the request is not uniform and needs to be adjusted by yourself
POST requestThe request method is slightly different from that of GET. First, you need to introduce the request header {Headers}
import { Http, Jsonp, Headers } from '@angular/http'
and then To define the request headers, you need to instantiate Headers first
private headers = new Headers({'Content-Type': 'application/json'})
Finally bring Headers when submitting data
postData() { let url = 'http://localhost:8080/login' let data = { "username": "zhangsan", "password": "123" } this.http.post( url, data, {headers: this.headers} ).subscribe((data) => { console.log(data) }) }
I believe you have mastered the method after reading the case in this article, and there will be more exciting things Please pay attention to other related articles on php Chinese website!
Recommended reading:
How to operate node and use promise instead of callback functionHow to use Vue better-scroll to implement the mobile terminal Alphabetical Index NavigationThe above is the detailed content of How to operate Angular to implement data request. For more information, please follow other related articles on the PHP Chinese website!