[Angular 2] Inject Service with "Providers"
In this lesson, we’re going to take a look at how add a class to the providers property of a component creates an actual providers. We’ll learn what a provider specifically does and how we can provide different dependencies with the same token.
import {Component} from 'angular2/core';
import {TodoService} from './../services/TodoService';
@Component({
    selector: 'todos',
    providers: [TodoService],
    template: `
        <div>
            <ul>
                <li *ngFor="#todo of todoService.todos
                    {{todo.name}}
                </li>
            </ul>
        </div>
    `
})
export class TodoList implements OnInit{
    todos: Array<any>
    constructor(private todoService: TodoService){}
    ngOnInit(){
        this.todos = this.todoService.getTodos();
    }
}
import {Injectable} from '@angular/core';
@Injectable()
export class TodoService {
    todos = [
        {id: , name: "eat"},
        {id: , name: "sleep"},
        {id: , name: "running"},
    ];
    getTodos(){
        return this.todos;
    }
}
Here we use providers, which tell Angular, we want to use TodoService, create a instance for us, and so that we can use the instance.
providers: [TodoService],
Actually, this is shorthard syntax, you can do:
providers: [
{ provider: TodoService, useClass: TodoService}
],
Here need to make sure, "provider" 's token are the same use "userClass", if you change "userClass" to some other service, it will still use the "TodoService":
providers: [
{ provide: TodoService, useClass: OtherService} // still use TodoService instead
],
To recap importing a data really just makes the type available, but doesn't give us an instance. In order to inject objects, we need providers that know how to create these objects by a given token which is a type.
[Angular 2] Inject Service with "Providers"的更多相关文章
- [Angular 2] Inject Service
		
TypeScript is used heavily as we build up our application, but TypeScript isn’t required. If you wan ...
 - 在Angular中定义共享的Providers
		
转自:https://segmentfault.com/a/1190000010700308 有时,你需要在 Angular 应用中创建一个共享模块,该模块定义了功能模块和lazy-loaded模块可 ...
 - [Angular 2] Use Service use Typescript
		
When creating a service, need to inject the sercive into the bootstrap(): import {bootstrap, Compone ...
 - Guice 学习(六)使用Provider注入服务( Provider Inject Service)
		
1.定义接口 package com.guice.providerInject; import com.google.inject.ProvidedBy; public interface Servi ...
 - [Angular] 'providedIn' for service
		
There is now a new, recommended, way to register a provider, directly inside the @Injectable() decor ...
 - angular js自定义service的简单示例
		
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
 - Angular 学习笔记——service &constant
		
<!DOCTYPE HTML> <html ng-app="myApp"> <head> <meta http-equiv="C ...
 - Angular:使用service进行http请求的简单封装
		
①使用ng g service services/storage创建一个服务组件 ②在app.module.ts 中引入HttpClientModule模块 ③在app.module.ts 中引入创建 ...
 - Angular:使用service进行数据的持久化设置
		
①使用ng g service services/storage创建一个服务组件 ②在app.module.ts 中引入创建的服务 ③利用本地存储实现数据持久化 ④在组件中使用
 
随机推荐
- HDU 5407  CRB and Candies
			
题意:给一个正整数k,求lcm((k, 0), (k, 1), ..., (k, k)) 解法:在oeis上查了这个序列,得知答案即为lcm(1, 2, ..., k + 1) / (k + 1),而 ...
 - [Everyday Mathematics]20150108
			
设 $f$ 在 $(a,b)$ 上 $n+1$ 次可导, 且 $$\bex \ln\frac{f(b)+f'(b)+\cdots+f^{(n)}(b)}{f(a)+f'(a)+\cdots+f^{(n ...
 - 回调函数、Java接口回调 总结
			
谈到回调,我们得先从回调函数说起,什么叫回调函数呢? 回调函数是什么? 百度百科的解释:回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用为调用 ...
 - Android 打勾显示输入的密码
			
main.xml: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:and ...
 - codeforces 700C Break Up 暴力枚举边+边双缩点(有重边)
			
题意:n个点,m条无向边,每个边有权值,给你 s 和 t,问你至多删除两条边,让s,t不连通,问方案的权值和最小为多少,并且输出删的边 分析:n<=1000,m是30000 s,t有4种情况( ...
 - 一个可序列化的C#对象,如何转成一个XML格式的文件或字符串【转】
			
原文:http://blog.csdn.net/otong/article/details/7894059 序列化或反序列化成一个字符串: 方法一: 序列化: public static string ...
 - android Loger日志类(获取内置sd卡)
			
Android手机自带内部存储路径的获取 原文地址:http://my.oschina.net/liucundong/blog/288183 直接贴代码: public static String g ...
 - redo文件三
			
switch logfile是一种昂贵的操作,在进行日志切换的时候,是不允许生成新的redo信息 在前台进程生成redo日志信息的时候,此时redo buffer已经分配了空间,并且在当前的redo日 ...
 - 《Genesis-3D开源游戏引擎-官方录制系列视频教程:进阶实例篇》
			
注:本系列教程仅针对引擎编辑器:v1.2.2及以下版本 G3D进阶实例 第四课<2D编辑与脚本的统一入口> 使用G3D完成一个简单的类飞机大战游戏,介绍了G3D2d游戏制作的流程包括: ...
 - django form关于clean及cleaned_data的说明 以及4种初始化
			
1.form类的运行顺序是init,clean,validte,save其中clean和validate会在form.is_valid()方法中被先后调用.(这里留有一个疑问,结构完全相同的两个f ...