Angular 4依赖注入学习教程之组件服务注入(二)


Posted in Javascript onJune 04, 2017

学习目录

  • Angular 4 依赖注入教程之一 依赖注入简介
  • Angular 4 依赖注入教程之二 组件服务注入
  • Angular 4 依赖注入教程之三 ClassProvider的使用
  • Angular 4 依赖注入教程之四 FactoryProvider的使用
  • Angular 4 依赖注入教程之五 FactoryProvider配置依赖对象
  • Angular 4 依赖注入教程之六 Injectable 装饰器
  • Angular 4 依赖注入教程之七 ValueProvider的使用
  • Angular 4 依赖注入教程之八 InjectToken的使用

前言

之前的一篇文章已经介绍了Angular 4 依赖注入的基础知识,下面将介绍Angular 4依赖注入之组件服务注入的相关内容,分享出来供大家参考学习,下面来来看看详细的介绍:

本系列教程的开发环境及开发语言:

  • Angular 4 +
  • Angular CLI
  • TypeScript

基础知识

如何创建 Angular 组件

在 Angular 中我们通过以下方式创建一个简单的组件:

@Component({
 selector: 'app-root',
 template: `
 <h1>{{title}}</h1>
 `
})
export class AppComponent {
 title: string = 'App Works';
}

如何创建 Angular 服务

在 Angular 中我们通过以下方式创建一个简单的服务:

export class DataService {
 getData() {
 return ['Angular', 'React', 'Vue'];
 }
}

组件中注入服务

介绍完基础知识,接下来我们来创建一个新的组件 - HeroComponent,它用来显示英雄的信息,具体实现如下:

import { Component, OnInit } from '@angular/core';

@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 }>;

 ngOnInit() {
 this.heros = [
 { id: 11, name: 'Mr. Nice' },
 { id: 12, name: 'Narco' },
 { id: 13, name: 'Bombasto' },
 { id: 14, name: 'Celeritas' },
 { id: 15, name: 'Magneta' }
 ];
 }
}

在 HeroComponent 组件中,我们在 ngOnInit 钩子中进行数据初始化,然后利用 ngFor 指令来显示英雄列表的信息。创建完 HeroComponent 组件,我们要来验证一下该组件的功能。

首先在 AppModule 中导入 HeroComponent 组件,具体如下:

import { HeroComponent } from './hero/hero.component';

@NgModule({
 declarations: [
 AppComponent,
 HeroComponent
 ],
 ...
})
export class AppModule { }

然后更新一下 AppComponent 组件,具体如下:

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 <app-hero></app-hero>
 `
})
export class AppComponent {}

如果不出意外的话,访问 http://localhost:4200/ 页面,您将看到如下信息:

ID: 11 - Name: Mr. Nice
ID: 12 - Name: Narco
ID: 13 - Name: Bombasto
ID: 14 - Name: Celeritas
ID: 15 - Name: Magneta

难道一切就这么结束了,No! No!别忘记了我们这节课的主题是介绍如何在组件中注入服务。在目前的 HeroComponent 组件,我们的英雄列表信息是固定的,在实际的开发场景中,一般需要从远程服务器获取相应的信息。但我们暂不考虑这个问题,假设另外一个组件也需要利用同样的英雄列表信息,那我们要怎么办,难道直接上 "终极绝招" - Copy && Paste 。当然这是 "终极绝招",岂能随便使用 (不怕被群殴的话,请自便哈)。

针对上面提到的问题,理想的方式是创建一个 HeroService 服务,从而实现数据共享。

说干就干,我们马上来创建 HeroService 服务,具体如下:

export class HeroService {
 heros: Array<{ id: number; name: string }> = [
 { id: 11, name: 'Mr. Nice' },
 { id: 12, name: 'Narco' },
 { id: 13, name: 'Bombasto' },
 { id: 14, name: 'Celeritas' },
 { id: 15, name: 'Magneta' }
 ];

 getHeros() {
 return this.heros;
 }
}

在 HeroService 服务中,我们定义了一个 heros 属性和一个 getHeros() 方法:

  • heros - 用于保存英雄的列表信息
  • getHeros() - 用于获取英雄的列表信息

创建完 HeroService 服务后,接下来我们来介绍如何在组件中使用 HeroService 服务。

组件中使用 HeroService

组件中使用 HeroService 服务,主要分为三个步骤:

1、导入 HeroService 服务

import { HeroService } from '../hero.service';

2、声明 HeroService 服务

@Component({
 selector: 'app-hero',
 ...
 providers: [HeroService]
})

注入 HeroService 服务

export class HeroComponent implements OnInit {
 constructor(private heroService: HeroService) { }
}

完整代码如下:

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>
 `,
 providers: [HeroService]
})
export class HeroComponent implements OnInit {

 constructor(private heroService: HeroService) { }

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

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

看到 providers: [HeroService] 这一行,相信有一些读者会有一些困惑,因为他们可能是按照下面的方式去配置 HeroService 服务。

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

当然两种方式不会影响,我们最终要实现的功能,但这两种方式肯定是有区别的,希望有兴趣的读者,去思考一下哈。在多数场景下,推荐在 NgModule 的 Metadata 信息中配置相应的服务。

我有话说

为什么配置完 HeroService ,在 HeroComponent 组件类的构造函数中还得进行类型声明?

import { HeroService } from '../hero.service';

export class HeroComponent implements OnInit {
 constructor(private heroService: HeroService) { }
}

其实在 @NgModule({...}) @Component({...}) Metadata 中我们只是配置 Provider 的相关信息,即告诉 Angular DI (依赖注入) 系统,如何创建根据配置的 provider 信息,创建相应的依赖对象。而在 HeroComponent 组件类中,我们通过构造注入的方式去告诉 Angular DI 系统,我们需要的依赖对象类型。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
“不能执行已释放的Script代码”错误的原因及解决办法
Sep 09 Javascript
漂亮的jquery提示效果(仿腾讯弹出层)
Feb 05 Javascript
利用js实现遮罩以及弹出可移动登录窗口
Jul 08 Javascript
Javascript连接多个数组不用concat来解决
Mar 24 Javascript
node.js中的http.response.addTrailers方法使用说明
Dec 14 Javascript
用Move.js配合创建CSS3动画的入门指引
Jul 22 Javascript
JavaScript实现打开链接页面的方式汇总
Jun 02 Javascript
Node.js Addons翻译(C/C++扩展)
Jun 12 Javascript
值得分享的bootstrap table实例
Sep 22 Javascript
浅谈angular.copy() 深拷贝
Sep 14 Javascript
JS实现吸顶特效
Jan 08 Javascript
解决vue项目运行提示Warnings while compiling.警告的问题
Sep 18 Javascript
JavaScript箭头(arrow)函数详解
Jun 04 #Javascript
Angular 4依赖注入学习教程之简介(一)
Jun 04 #Javascript
angularJs中datatable实现代码
Jun 03 #Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
Jun 03 #Javascript
详解JavaScript调用栈、尾递归和手动优化
Jun 03 #Javascript
详解有关easyUI的拖动操作中droppable,draggable用法例子
Jun 03 #Javascript
利用vueJs实现图片轮播实例代码
Jun 03 #Javascript
You might like
全国FM电台频率大全 - 25 云南省
2020/03/11 无线电
星际争霸 Starcraft 编年史
2020/03/14 星际争霸
PHP随机字符串生成代码(包括大小写字母)
2013/06/24 PHP
Javascript 命名空间模式
2013/11/01 Javascript
JS阻止冒泡事件以及默认事件发生的简单方法
2014/01/17 Javascript
jQuery遍历Table应用示例
2014/04/09 Javascript
js加入收藏夹代码(兼容ie/ff/op)
2014/05/16 Javascript
javascript中的throttle和debounce浅析
2014/06/06 Javascript
html的DOM中document对象images集合用法实例
2015/01/21 Javascript
js数组去重的方法汇总
2015/07/29 Javascript
bootstrapValidator.min.js表单验证插件
2017/02/09 Javascript
纯js实现的积木(div层)拖动功能示例
2017/07/19 Javascript
使用nodeJs来安装less及编译less文件为css文件的方法
2017/11/20 NodeJs
小程序云函数调用API接口的方法
2019/05/17 Javascript
微信小程序文章详情页跳转案例详解
2019/07/09 Javascript
jQuery+Ajax+js实现请求json格式数据并渲染到html页面操作示例
2020/06/02 jQuery
解决ant design vue中树形控件defaultExpandAll设置无效的问题
2020/10/26 Javascript
Vue实现简易购物车页面
2020/12/30 Vue.js
JavaScript实现消消乐的源代码
2021/01/12 Javascript
[39:11]DOTA2上海特级锦标赛C组资格赛#2 LGD VS Newbee第二局
2016/02/28 DOTA
浅析python递归函数和河内塔问题
2017/04/18 Python
Python实现的选择排序算法原理与用法实例分析
2017/11/22 Python
python爬虫模块URL管理器模块用法解析
2020/02/03 Python
利用python实现凯撒密码加解密功能
2020/03/31 Python
PyQt5实现登录页面
2020/05/30 Python
pytorch读取图像数据转成opencv格式实例
2020/06/02 Python
python 实现客户端与服务端的通信
2020/12/23 Python
canvas基础之图形验证码的示例
2018/01/02 HTML / CSS
美国艺术和工艺品商店:Hobby Lobby
2020/12/09 全球购物
优秀中专生推荐信
2013/11/17 职场文书
给孩子的新年寄语
2014/04/08 职场文书
三八妇女节趣味活动方案
2014/08/23 职场文书
标准版离职证明书
2014/09/12 职场文书
退休党员个人对照检查材料思想汇报
2014/09/29 职场文书
死磕 java同步系列之synchronized解析
2021/06/28 Java/Android
NoSQL优缺点与MongoDB数据库简介
2022/06/05 MongoDB