(六)依赖注入基础
2017-07-18 本文已影响0人
马丁路德东
依赖注入是提高组件可重用性的主要方法,解决组件之间的松耦合(也叫什么控制反转)概念性问题。
最基础的依赖注入
1.基础服务的写法
data:image/s3,"s3://crabby-images/c6428/c6428bee31053504560ce904543eeb9faacc721f" alt=""
2.在模板上引入他
data:image/s3,"s3://crabby-images/90502/905029156352fcf401b0f8ead3ee1046f601a803" alt=""
3.在组建的控制器的构造函数里接受服务,然后再HTML上展示就行
data:image/s3,"s3://crabby-images/c8a34/c8a34dd9468bf52f5cf87631e0c305cfc9f4c357" alt=""
(二)进阶版注入依赖------声明在组件里。
1.写服务时,可以借助其他服务
data:image/s3,"s3://crabby-images/3413b/3413bac1917f399d42a251c9ad9d6b6263fe47c1" alt=""
2.组件中注入服务
data:image/s3,"s3://crabby-images/fa0d9/fa0d940740d42dff6dbdefda48eb188e42c8aeda" alt=""
我们一般将服务声明在模块层,除非此服务必须对其他组件不可见是才将他声明在组件中
(三)服务之间的相互注入。
1.服务书写和以前一样
注意只有服务有@Injectable装饰器,服务才能允许注入其他服务。
data:image/s3,"s3://crabby-images/9bc8e/9bc8e65d28caf2144f1d9f77ef262f31721409ca" alt=""
2.服务接受语法,和以前一样。
data:image/s3,"s3://crabby-images/d9f27/d9f27a4b008a31583ed1fe9121c3a5415e0724af" alt=""
3.在模块中声明他
data:image/s3,"s3://crabby-images/967d0/967d0f802ceb64026714798631b490c19370c1fb" alt=""