欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular 4 依賴注入學習教程之FactoryProvider的使用(四)

 更新時間:2017年06月04日 09:44:05   作者:semlinker  
這篇文章主要給大家介紹了關于Angular 4 依賴注入之FactoryProvider使用的相關資料,文中介紹的非常詳細,對大家學習或者使用Angular4具有一定的參考學習價值,需要的朋友們下面來一起看看吧。

學習目錄

前言

本文屬于Angular 4 依賴注入學習系列的第四篇,主要介紹了Angular 4 依賴注入之FactoryProvider的使用,感興趣的朋友們下面來看看詳細的介紹:

本系列教程的開發(fā)環(huán)境及開發(fā)語言:

基礎知識

FactoryProvider 的作用

FactoryProvider 用于告訴 Injector (注入器),通過調用 useFactory 對應的函數(shù),返回 Token 對應的依賴對象。

FactoryProvider 的使用

function serviceFactory() { 
 return new Service();
}

const provider: FactoryProvider = {
 provide: 'someToken', useFactory: serviceFactory, deps: []
};

FactoryProvider 接口

export interface FactoryProvider {
 // 用于設置與依賴對象關聯(lián)的Token值,Token值可能是Type、InjectionToken、
 // OpaqueToken的實例或字符串
 provide: any;
 // 設置用于創(chuàng)建對象的工廠函數(shù)
 useFactory: Function;
 // 依賴對象列表
 deps?: any[];
 // 用于標識是否multiple providers,若是multiple類型,則返回與Token關聯(lián)的依賴
 // 對象列表
 multi?: boolean;
}

FactoryProvider

介紹完基礎知識,接下來我們馬上進入正題。不知道大家是否還記得,之前我們創(chuàng)建過的 HeroComponent 組件:

import { Component, OnInit } from '@angular/core';
import { HeroService } from '../hero.service';

@Component({
 selector: 'app-hero',
 template: `
 <ul>
 <li *ngFor="let hero of heros">
 ID: {{hero.id}} - Name: {{hero.name}}
 </li>
 </ul>
 `
})
export class HeroComponent implements OnInit {

 constructor(private heroService: HeroService) { }

 heros: Array<{ id: number; name: string }>;

 ngOnInit() {
 this.heros = this.heroService.getHeros();
 }
}

那么現(xiàn)在問題來了,假設我們想在獲取英雄數(shù)據(jù)時,輸出調試信息,那應該怎么辦?What ~,這個問題不是很簡單么,直接使用 console.log API 輸出相應信息不就行了么:

console.log('Fetching heros...');
this.heros = this.heroService.getHeros();

那問題又來了,如果多個組件都使用 HeroService 去獲取英雄數(shù)據(jù),那么是不是每個組件都得添加對應的語句。另外如果要修改輸出的調試信息,那就得修改程序中多個地方。其實我們一般只需要在開發(fā)階段,輸出調試信息,因此上面的方案不合理,也不夠靈活。

其實我們可以借鑒之前引入 HeroService 服務的思路,創(chuàng)建一個 LoggerService 來解決上面提到的問題。

創(chuàng)建 LoggerService 服務

export class LoggerService {
 constructor(private enable: boolean) { }

 log(message: string) {
 if(this.enable) {
  console.log(`LoggerService: ${message}`);
 }
 }
}

配置 LoggerService 服務

@NgModule({
 ...
 providers: [
 HeroService,
 LoggerService
 ],
 bootstrap: [AppComponent]
})
export class AppModule { }

使用 LoggerService 服務

import { Component, OnInit } from '@angular/core';
import { HeroService } from '../hero.service';
import { LoggerService } from './../logger.service';

@Component({
 selector: 'app-hero',
 template: `
 <ul>
 <li *ngFor="let hero of heros">
 ID: {{hero.id}} - Name: {{hero.name}}
 </li>
 </ul>
 `
})
export class HeroComponent implements OnInit {
 heros: Array<{ id: number; name: string }>;

 constructor(private heroService: HeroService,
 private loggerService: LoggerService) { }

 ngOnInit() {
 this.loggerService.log('Fetching heros...');
 this.heros = this.heroService.getHeros();
 }
}

以上代碼運行后會拋出以下異常信息:

Uncaught Error: Can't resolve all parameters for LoggerService: (?).

有的讀者,眼睛一亮,可能是你在創(chuàng)建 LoggerService 服務時,忘記使用 @Injectable 裝飾器了。哈哈,其實我是故意的,但我加上 @Injectable() 后,還是拋出了以下異常:

ERROR Error: No provider for Boolean!

為什么會出現(xiàn)上面的異常信息呢?我們再看一下前面創(chuàng)建的 LoggerService 服務:

export class LoggerService {
 constructor(private enable: boolean) { }
 // ...
}

在 Angular 中我們通過構造注入的方式注入依賴對象, private enable: boolean 這種方式表示我們要注入 Type 類型的對象。然后 boolean 是表示基本數(shù)據(jù)類型,并不是所需的 Type 類型:

export function isType(v: any): v is Type<any> {
 return typeof v === 'function';
}

接下來我們再來看一下最早拋出的異常:

Uncaught Error: Can't resolve all parameters for LoggerService: (?).

其實問題的答應也在 LoggerService 類的構造函數(shù)中,在創(chuàng)建 LoggerService 對象時,我們需要設置 enable 參數(shù)的值。那么如何解決呢? 當然可以使用我們的主角 - FactoryProvider 。

具體如下:

使用 FactoryProvider

@NgModule({
 ...,
 providers: [
 HeroService,
 {
 provide: LoggerService, 
 useFactory: () => {
 return new LoggerService(true);
 }
 }
 ],
 bootstrap: [AppComponent]
})
export class AppModule { }

當更新完代碼,然后再來一個華麗的保存操作,最后打開你的控制臺,你將看到預期的輸出信息:

LoggerService: Fetching heros...

難道就這樣結束了,關于 FactoryProvider 的相關內容先告一段落,下一篇我們將介紹如何使用 FactoryProvider 配置依賴對象。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者使用Angular 4能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • AngularJS ng-style中使用filter

    AngularJS ng-style中使用filter

    這篇文章主要介紹了AngularJS ng-style中使用filter的相關資料,需要的朋友可以參考下
    2016-09-09
  • AngularJS入門教程之MVC架構實例分析

    AngularJS入門教程之MVC架構實例分析

    這篇文章主要介紹了AngularJS的MVC架構,結合實例形式重點分析了ng-controller聲明并使用控制器的操作技巧與控制器作用域的相關注意事項,需要的朋友可以參考下
    2016-11-11
  • 淺析AngularJS中的指令

    淺析AngularJS中的指令

    指令(Directives)是所有AngularJS應用最重要的部分。盡管AngularJS已經(jīng)提供了非常豐富的指令,但還是經(jīng)常需要創(chuàng)建應用特定的指令
    2016-03-03
  • 詳解Angular4 路由設置相關

    詳解Angular4 路由設置相關

    本篇文章主要介紹了詳解Angular4 路由設置相關,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Angular2 Service實現(xiàn)簡單音樂播放器服務

    Angular2 Service實現(xiàn)簡單音樂播放器服務

    本篇文章主要介紹了Angular2 Service實現(xiàn)簡單音樂播放器服務 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • AnglarJs中的上拉加載實現(xiàn)代碼

    AnglarJs中的上拉加載實現(xiàn)代碼

    上拉加載,是目前手機網(wǎng)站加載數(shù)據(jù)的一種常用方式,本文主要講解AnglarJs集成,上拉加載功能。感興趣的朋友跟隨腳本之家小編一起學習吧
    2018-02-02
  • Angularjs中如何使用filterFilter函數(shù)過濾

    Angularjs中如何使用filterFilter函數(shù)過濾

    這篇文章主要介紹了Angularjs中如何使用filterFilter函數(shù)過濾的相關資料,需要的朋友可以參考下
    2016-02-02
  • Angular中的NgZone.run()有什么用途

    Angular中的NgZone.run()有什么用途

    在Angular中,NgZone是一個服務,用于管理異步任務的執(zhí)行,并提供一種在Angular區(qū)域內或外部顯式運行代碼的方式,NgZone.run方法是一種顯式在Angular區(qū)域內運行函數(shù)的方式,本文介紹Angular中的NgZone.run()有什么用,感興趣的朋友一起看看吧
    2024-01-01
  • AngularJS實現(xiàn)動態(tài)編譯添加到dom中的方法

    AngularJS實現(xiàn)動態(tài)編譯添加到dom中的方法

    這篇文章主要介紹了AngularJS實現(xiàn)動態(tài)編譯添加到dom中的方法,結合實例形式分析了AngularJS動態(tài)編輯構建模板的相關操作技巧,需要的朋友可以參考下
    2016-11-11
  • Angularjs的$http異步刪除數(shù)據(jù)詳解及實例

    Angularjs的$http異步刪除數(shù)據(jù)詳解及實例

    這篇文章主要介紹了Angularjs的$http異步刪除數(shù)據(jù)詳解及實例的相關資料,這里提供實現(xiàn)思路及實現(xiàn)具體的方法,需要的朋友可以參考下
    2017-07-07

最新評論