ホームページ > 記事 > ウェブフロントエンド > angular2 の HTTP リクエストの原則について (詳細なチュートリアル)
この記事では、主に angular2 での HTTP リクエストの原理と使用法を紹介し、AngularJS の http 関連モジュールを分析して http サービス リクエストと対応する関連操作テクニックをサンプルの形式で実装します。 angular2 Http リクエストの原理と使用法の例を説明します。参考のために皆さんと共有してください。詳細は次のとおりです:
HTTPサービスを提供します
HttpModuleはAngularのコアモジュールではありません。 これは、Angular が Web アクセスに使用するオプションのメソッドであり、@angular/http
という別のサテライト モジュールにあります。Edit app.module.ts@angular/http
的独立附属模块中.
编辑app.module.ts
import { HttpModule, JsonpModule } from '@angular/http'; @NgModule({ imports: [ HttpModule, JsonpModule ], })
angular-in-memory-web-api
npm install angular-in-memory-web-api --save-dev
This in-memory web api service processes an HTTP request and returns an Observable of HTTP Response object in the manner of a RESTy web api.
:base/:collectionName/:id? GET api/heroes // all heroes GET api/heroes/42 // the character with id=42 GET api/heroes?name=^j // 'j' is a regex; returns heroes whose name starting with 'j' or 'J' GET api/heroes.json/42 // ignores the ".json"
之前测试时用的app/mock/user_data_memory_mock.ts数据
import {User} from '../model/User'; import { InMemoryDbService } from 'angular-in-memory-web-api'; export class UserDataMemoryMock implements InMemoryDbService{ createDb() { const users: User[] = [ new User('chenjianhua_a', 21, '2290910211@qq.com', '123456'), new User('chenjianhua_b', 22, '2290910211@qq.com', '123456'), new User('chenjianhua_c', 23, '2290910211@qq.com', '123456'), new User('chenjianhua_d', 24, '2290910211@qq.com', '123456'), new User('chenjianhua_e', 25, '2290910211@qq.com', '123456'), new User('chenjianhua_f', 26, '2290910211@qq.com', '123456'), ]; return {users}; } }
编辑app.module.ts
import { InMemoryWebApiModule } from 'angular-in-memory-web-api'; import { UserDataMemoryMock } from './mock/user_data_memory_mock'; @NgModule({ imports: [ InMemoryWebApiModule.forRoot(UserDataMemoryMock), ] })
导入InMemoryWebApiModule并将其加入到模块的imports数组。 InMemoryWebApiModule将Http客户端模拟的后端服务 forRoot()
import {Injectable} from '@angular/core'; import { Headers, Http } from '@angular/http'; import 'rxjs/add/operator/toPromise'; import { User } from '../model/User'; import { Logger } from './logger.service'; @Injectable() export class UserService { private USERURL = 'api/users'; private headers = new Headers({'Content-Type': 'application/json'}); constructor(private Log: Logger, private http: Http) { } getUserByName(name: string): Promise<User> { const url = `${this.USERURL}/?name=${name}`; return this.http.get(url) .toPromise() .then(response => response.json().data as User) .catch(this.handleError); } getUsers(): Promise<User[]> { console.log('Get User!'); return this.http.get(this.USERURL) .toPromise() .then(response => response.json().data as User[]) .catch(this.handleError); } create(name: string): Promise<User> { return this.http .post(this.USERURL, JSON.stringify({name: name}), {headers: this.headers}) .toPromise() .then(res => res.json().data as User) .catch(this.handleError); } private handleError(error: any): Promise<any>{ console.log('An error occurred :', error); return Promise.reject(error.message); } }
angular-in-memory。 -web-api
import { Component, OnInit } from '@angular/core'; import { Logger } from '../../service/logger.service'; import { UserService } from '../../service/user.restful.service'; import { User } from '../../model/User'; import { Subject } from 'rxjs/Subject'; @Component({ selector: 'app-loginform', templateUrl: './app.loginform.html', styleUrls: ['./app.loginform.css'], providers: [ Logger, UserService ] }) export class AppLoginFormComponent implements OnInit { users: User[]; submitted = false; model = new User('1', 'fangfang', 22, '2290910211@qq.com', '123456'); constructor( private Log: Logger, private userService: UserService ){} ngOnInit(): void{ this.userService .getUsers() .then( users => this.users = users); } onSubmit(): void { this.userService.getUserByName(this.model.name) .then( user => { console.log('user.name', user[0].name); console.log('user.password', user[0].password); if(user[0].name === this.model.name && user[0].password === this.model.password){ this.Log.log('login success!'); this.submitted = true; }else{ this.Log.log('login failed!'); this.submitted = false; } }) .catch(errorMsg => console.log(errorMsg)); } }このインメモリ Web API サービスは、HTTP リクエストを処理し、RESTy Web API の方法で HTTP Response オブジェクトの Observable を返します。rrreee 以前の app/mock/user_data_memory_mock のテストに使用されます。 ts データ
rrreee app.module.tsrrreee
Import InMemoryWebApiModule を編集し、モジュールの imports 配列に追加します。 InMemoryWebApiModule は、HTTP クライアントのバックエンド サービスをシミュレートしますforRoot()
設定メソッドでは、メモリ データベースにデータを埋めるために UserMemoryMockService クラス インスタンスが必要です
app/service/user.restful を編集します.service.ts
rrreee
app/components/app-loginform/app.loginform.ts
HTTP Promiseを編集すると、RxJS Observable オブジェクトが返されます。 Observable は、非同期データ ストリームを管理する強力な方法です。ここで、まず toPromise メソッドを使用して、Observable を Promise オブジェクトに直接変換します。
上記は、私が皆さんのためにまとめたものです。将来的に皆さんの役に立つことを願っています。JavaScriptの再帰的トラバーサルと非再帰的トラバーサル
🎜VUEの個人的なまとめ(遭遇した問題)🎜🎜🎜🎜Nuxt.js Vueのサーバーサイドレンダリングの探索🎜🎜🎜🎜letの定義バーインjs 変数間の違いは何ですか? 🎜🎜🎜🎜vueでは、watchがオブジェクトプロパティの変更を検出しないという問題があります🎜🎜以上がangular2 の HTTP リクエストの原則について (詳細なチュートリアル)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。