Angular的依赖注入

依赖注入(DI)是一种重要的应用设计模式。

依赖,当类需要执行其功能时,所需要的服务或对象。DI是一种编码模式,其中的类会从外部源中请求获取依赖,而不需要我们自己创建它们

依赖注入就是当类需要一个东西,而他已经存在,就可以直接拿来使用,不需要自己创建。(高复用,低耦合)

Angular系统中通过类上添加@Injectable装饰器来告诉系统这个类(服务)是可注入的。

一、注入器

        1)、用来管理服务(创建、获取)

        2)、冒泡机制

1、NgModule

// 该类可被注入实例化,可以在别的组件中通过依赖注入的方式来使用

@Injectable({
    
})

// 注入方式一
// 在angular的根模块NgModule的providers中声明这个服务:限制服务只能在当前ngModule中使用
@ngModule({
    providers:[ClassName]
})

// 注入方式二

@Injectable({
    providedIn:NgModule | 'root' | null
/*
null - 可注入,未指定使用位置
‘root’ - 可在整个Angular应用中使用,且只有一份服务实例
NgModule - 不能直接写对应的NgModule,需要一个过渡的NgModule
*/

})

// 在使用该组件的对象中
import { ClassName } from '../class.service';

constructor(private ClassName:ClassName){}

2、Component

        1)、该组件实例或其下级组件实例都可以使用这个服务(可设置)

@Component({
    // ...
    providers: [ComponentInjectService],   // providers提供的服务在当前组件和子组件都可以使用
    // viewProviders: [ComponentInjectService], // viewProviders提供的服务在当前组件使用
})

        2)、生命周期:该组件的每个实例都会获取自己的一份服务实例,当销毁组件实例的时候,服务实例也会被同时销毁

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值