首頁 web前端 js教程 深度解析AngularJS依賴注入原理

深度解析AngularJS依賴注入原理

Mar 28, 2018 pm 03:06 PM
angularjs 依賴注入

本文主要為大家分享一篇深度解析AngularJS依賴注入原理,具有很好的參考價值,希望對大家有幫助。一起跟著小編過來看看吧。

依賴注入:Dependency Injection 簡稱DI

#範例:

var xiaomi = new Xiaomi();     // 假设小米公司生产了一台xiaomi手机
createShipment(xiaomi);         //此方法能把货送给顾客,这叫做把小米手机注入到createShipment()方法
登入後複製

再假設createShipment ()方法需要(手機,快遞公司,訂單詳情)三個參數時,就需要:

var xiaomi = new Xiaomi();     // 不仅要生产手机
var shipCompany = new ShipCompany();   // 还要自己建立个快递公司
var order = new Order();      // 还要自己建立线上线下平台做订单
createShipmentxiaomi,shipCompany,order);   // 虽然小米已经这么干了,但还是很累的
登入後複製

上面的例子,小米除了在自己開的店裡賣就沒別的通路了嗎?不只要做手機,還要自己接生意,還要自己做快遞,不累嗎?除了自己幹,小米還能在淘寶,京東,蘇寧等平台賣啊,還能利用三通一順等快遞公司來送貨啊,這就是依賴注入要解決的問題。利用淘寶京東順豐等公司就是為小米公司注入販賣服務(sellService), 快遞服務(sendService) 等等!

控制反轉:Inversion of Control 簡稱IOC

IOC是指將依賴的控制權從程式碼的內部轉到程式碼的內部。好比小米把賣手機送貨的權力給了外部,至於是淘寶在賣還是京東在賣,是圓通在送還是順豐在送,這些都不用小米公司操心,小米公司只需要造手機就行了。專業的事交給專業的人去做。

IOC是一種鬆散耦合的模式,實現的手段就是依賴注入。

注入器:

constructor(private someService: SomeService) {...}

這句話的意思是這個元件宣告了一個##someService#的屬性,指明它的類型是SomeService,然後angular就會去提供器去找SomeService的一個實例,然後把這個實例注入到someService#。 #

提供器:

providers:[{provide:SomeService,useClass:SomeService}]

providers:[SomeService]//provideuseClass相同可简写为这个

例:

app.module.ts

@NgModule({  
    providers:[{provide:SellService,useClass:ShunfengService}],             // 这个是淘宝,用的顺丰
      // providers: [{provide:SellService,useClass:YuantongService}]          // 这个是京东,用的圆通})
product.component.ts
@Component({  ...
})
     export class ProductComponent implements OnInit {  product: Product;  constructor(sellService: SellService) {
        this.product = this.sellService.sendProduct();
  }}
登入後複製

上面的代码怎么理解呢?

小米声明sellService对象(也是属性),叫sellService去卖手机,sellService呼叫售卖服务,这个服务是SellService类型的(线上销售),那么angular就会去提供器里面找谁在提供这个售卖服务,至于是淘宝还是京东那要看提供器里面的,用的哪个快递公司就更加不需要小米公司来管了。angular找到SellService之后会new一个ShunfengService的一个实例(找一家顺丰门店),找到之后把服务注入给小米公司的sellServicesellService就跑到那家顺丰门店填送货单(sendProduct方法)把手机送给客户了。

各位看官应该能想出更好的比喻,欢迎交流。如果有不妥之处欢迎指正。

相关推荐:

AngularJS 依赖注入解析

AngularJS中的依赖注入

30行代码让你理解angular依赖注入:angular 依赖注入原理

以上是深度解析AngularJS依賴注入原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

手把手帶你了解Angular中的依賴注入 手把手帶你了解Angular中的依賴注入 Dec 02, 2022 pm 09:14 PM

這篇文章帶大家了解一下依賴注入,介紹一下依賴注入解決的問題和它原生的寫法是什麼,並聊聊Angular的依賴注入框架,希望對大家有所幫助!

在Phalcon框架中使用依賴注入(Dependency Injection)的方法 在Phalcon框架中使用依賴注入(Dependency Injection)的方法 Jul 30, 2023 pm 09:03 PM

在Phalcon框架中使用依賴注入(DependencyInjection)的方法引言:在現代的軟體開發中,依賴注入(DependencyInjection)是一種常見的設計模式,旨在提高程式碼的可維護性和可測試性。而Phalcon框架作為一個快速、低耗的PHP框架,也支援使用依賴注入來管理和組織應用程式的依賴關係。本文將向您介紹如何在Phalcon框架中

2022年最新5款的angularjs教學從入門到精通 2022年最新5款的angularjs教學從入門到精通 Jun 15, 2017 pm 05:50 PM

Javascript 是一個非常有個性的語言. 無論是從程式碼的組織, 還是程式碼的程式設計範式, 或物件導向理論都獨具一格. 而很早就在爭論的Javascript 是不是物件導向語言這個問題, 顯然已有答案. 但是, 即使Javascript 叱吒風雲二十年, 如果想要看懂jQuery, Angularjs, 甚至是React 等流行框架, 觀看《黑馬雲課堂JavaScript 高級框架設計視頻教程》就對了。

Golang函數參數傳遞中的依賴注入模式 Golang函數參數傳遞中的依賴注入模式 Apr 14, 2024 am 10:15 AM

在Go中,依賴注入(DI)模式透過函數參數傳遞實現,類型包括值傳遞和指標傳遞。在DI模式中,依賴項通常以指標傳遞,以提高解耦性、減少鎖爭用和支援可測試性。透過使用指針,函數與特定實作解耦,因為它只依賴介面類型。指標傳遞還可以減少傳遞大物件的開銷,從而減少鎖爭用。此外,DI模式可以輕鬆地為使用DI模式的函數編寫單元測試,因為可以輕鬆地模擬依賴項。

使用JUnit單元測試框架進行依賴注入 使用JUnit單元測試框架進行依賴注入 Apr 19, 2024 am 08:42 AM

針對使用JUnit測試依賴注入,摘要如下:使用模擬物件建立依賴項:@Mock註解可建立依賴項的模擬物件。設定測試資料:@Before方法在每個測試方法前執行,用於設定測試資料。配置模擬行為:Mockito.when()方法配置模擬物件的預期行為。驗證結果:assertEquals()斷言檢查實際結果與預期值是否相符。實際應用:可使用依賴注入框架(如SpringFramework)注入依賴項,透過JUnit單元測試驗證注入的正確性和程式碼的正常運作。

使用PHP和AngularJS建立響應式網站,提供優質的使用者體驗 使用PHP和AngularJS建立響應式網站,提供優質的使用者體驗 Jun 27, 2023 pm 07:37 PM

在現今資訊時代,網站已成為人們獲取資訊和交流的重要工具。一個響應式的網站能夠適應各種設備,為使用者提供優質的體驗,成為了現代網站開發的熱點。本篇文章將介紹如何使用PHP和AngularJS建立響應式網站,進而提供優質的使用者體驗。 PHP介紹PHP是一種開源的伺服器端程式語言,非常適合Web開發。 PHP具有許多優點,如易於學習、跨平台、豐富的工具庫、開發效

Go語言:依賴注入指南 Go語言:依賴注入指南 Apr 07, 2024 pm 12:33 PM

答案:在Go語言中,依賴注入可以透過介面和結構體來實現。定義一個描述依賴項行為的介面。建立一個實作該介面的結構體。在函數中透過介面作為參數注入依賴項。允許在測試或不同場景中輕鬆替換依賴項。

PHP 函數的依賴注入與服務容器 PHP 函數的依賴注入與服務容器 Apr 27, 2024 pm 01:39 PM

答:PHP中的依賴注入和服務容器有助於靈活地管理依賴項,提高程式碼可測試性。依賴注入:透過容器傳遞依賴項,避免在函數內直接創建,提升彈性。服務容器:儲存依賴項實例,方便在程式中訪問,進一步增強鬆散耦合。實戰案例:範例應用程式演示依賴注入和服務容器的實際應用,將相依性注入到控制器,體現鬆散耦合優勢。

See all articles