源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Angular 4依赖注入学习教程之FactoryProvider配置依赖对象(五)

  • 时间:2020-04-04 04:15 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Angular 4依赖注入学习教程之FactoryProvider配置依赖对象(五)
[b]学习目录[/b] [list] [*][url=http://www.1sucai.cn/article/115317.htm]Angular 4 依赖注入教程之一 依赖注入简介[/url][/*] [*][url=http://www.1sucai.cn/article/115319.htm]Angular 4 依赖注入教程之二 组件服务注入[/url][/*] [*][url=http://www.1sucai.cn/article/115320.htm]Angular 4 依赖注入教程之三 ClassProvider的使用[/url][/*] [*][url=http://www.1sucai.cn/article/115322.htm]Angular 4 依赖注入教程之四 FactoryProvider的使用[/url][/*] [*][url=http://www.1sucai.cn/article/115326.htm]Angular 4 依赖注入教程之五 FactoryProvider配置依赖对象[/url][/*] [*][url=http://www.1sucai.cn/article/115329.htm]Angular 4 依赖注入教程之六 Injectable 装饰器[/url][/*] [*][url=http://www.1sucai.cn/article/115333.htm]Angular 4 依赖注入教程之七 ValueProvider的使用[/url][/*] [*][url=http://www.1sucai.cn/article/115334.htm]Angular 4 依赖注入教程之八 InjectToken的使用[/url][/*] [/list] 本文主要给大家介绍了关于Angular 4依赖注入之FactoryProvider配置依赖对象的相关内容,分享出来供大家参考学习,下面来看看详细的介绍: [b]本系列教程的开发环境及开发语言:[/b] [list] [*][url=https://angular.io/]Angular 4 +[/url][/*] [*][url=https://github.com/angular/angular-cli]Angular CLI[/url][/*] [*][url=https://www.typescriptlang.org/index.html]TypeScript[/url][/*] [/list] [b]基础知识[/b] [b]Console 对象[/b] Console 对象可以在任何全局对象中访问,如 Window,WorkerGlobalScope 以及通过属性工作台提供的特殊定义。在浏览器中我们可以通过 Window.console 访问 console 对象,使用示例如下:
console.log('My nickname is semlinker');
[b]FactoryProvider 的作用 [/b] FactoryProvider 用于告诉 Injector (注入器),通过调用 useFactory 对应的函数,返回 Token 对应的依赖对象。 [b]FactoryProvider 接口 [/b]
export interface FactoryProvider {
 // 用于设置与依赖对象关联的Token值,Token值可能是Type、InjectionToken、
 // OpaqueToken的实例或字符串
 provide: any;
 // 设置用于创建对象的工厂函数
 useFactory: Function;
 // 依赖对象列表
 deps?: any[];
 // 用于标识是否multiple providers,若是multiple类型,则返回与Token关联的依赖
 // 对象列表
 multi?: boolean;
}
在 [url=http://www.1sucai.cn/article/115322.htm]FactoryProvider[/url]的使用 这篇文章中,我们已经介绍了 FactoryProvider 的一些相关知识。接下来我们将介绍如何使用 FactoryProvider 配置依赖对象。 [b]FactoryProvider[/b] 俗话说得好,温故而知新。我们先来回顾一下上一节创建的 LoggerService 服务:
export class LoggerService {
 constructor(private enable: boolean) { }

 log(message: string) {
 if(this.enable) {
  console.log(`LoggerService: ${message}`);
 }
 }
}
LoggerService 的正确配置方式如下:
@NgModule({
 ...,
 providers: [
 HeroService,
 {
 provide: LoggerService, 
 useFactory: () => {
 return new LoggerService(true);
 }
 }
 ],
 bootstrap: [AppComponent]
})
export class AppModule { }
在继续介绍前,我们先来了解一下 Angular 的一大特色: [b]跨平台开发[/b] 学习如何基于 Angular 构建应用程序,并复用代码和技能来构建适用于所有平台的应用。比如:Web应用、移动Web应用、原生移动应用和原生桌面应用等。 没错,Angular 框架的一大特色就是跨平台开发。回到正题,不知道读者有没有察觉到,在 LoggerService 类中的 log() 方法内,我们是直接使用 console.log() 方法输出调试信息。虽然在大多数情况下,我们的应用都是运行在浏览器环境下,但 console.log() 存在兼容性问题 (了解详细信息 - Can I Use)。除此之外,假如日后我们的应用需要运行在其它平台下,就会出现问题。 为了解决上述问题,我们可以创建一个 ConsoleService 服务,且该服务需实现统一的 Console 接口。但本文的重点不在这里,因此我们先简单实现一个 ConsoleService 服务:
export class ConsoleService {
 log(message) {
 console.log(`ConsoleService: ${message}`);
 }
}
接下来我们就需要更新先前的 LoggerService 服务:
export class LoggerService {
 constructor(private enable: boolean,
 consoleService: ConsoleService) { }

 log(message: string) {
 if (this.enable) {
  console.log(`LoggerService: ${message}`);
 }
 }
}
但当我们更新完 LoggerService ,成功保存后,你会看到以下异常信息:
app.module.ts (27,16): Supplied parameters do not match any signature of call target.
这说明提供的参数与调用目标的签名不匹配,这是因为在 AppModule 中,LoggerService 的配置方式是:
{
 provide: LoggerService, 
 useFactory: () => {
 return new LoggerService(true);
}
而此时 LoggerService 构造函数输入参数的个数为两个,因此会抛出上面的异常。那么我们应该怎么解决这个问题呢?这时我们就要利用 FactoryProvider 接口中定义的 deps 属性,来声明 LoggerService 所依赖的对象。 [b]配置 deps 属性[/b]
{
 provide: LoggerService, 
 useFactory: (consoleService) => {
 return new LoggerService(true, consoleService);
 },
 deps: [ConsoleService]
}
[b]更新 AppModule [/b]
@NgModule({
 ...,
 providers: [
 HeroService,
 ConsoleService,
 {
 provide: LoggerService, 
 useFactory: (consoleService) => {
 return new LoggerService(true, consoleService);
 },
 deps: [ConsoleService]
 }
 ],
 bootstrap: [AppComponent]
})
export class AppModule { }
当更新完代码,然后再来一个华丽的保存操作,最后打开你的控制台,你又看到预期的输出信息:
LoggerService: Fetching heros...
[b]我有话说[/b] [b]工厂函数是用来干嘛的?[/b] 在现实生活中,工厂是用来生产产品的,如鞋子工厂用来生产鞋子。而 FactoryProvider 接口中 useFactory 属性对应的工厂函数就是用来创建依赖对象。此外生产一双鞋子也需要对应的材料,如鞋底、鞋带等,而创建依赖对象也可能需要依赖其它对象,因此 FactoryProvider 接口中定义了 deps 属性用来声明依赖对象列表。 [b]总结[/b] 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者使用Angular 4能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部