深度解析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]//provide跟useClass相同可简写为这个
例:
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的一个实例(找一家顺丰门店),找到之后把服务注入给小米公司的sellService。sellService就跑到那家顺丰门店填送货单(sendProduct方法)把手机送给客户了。
各位看官应该能想出更好的比喻,欢迎交流。如果有不妥之处欢迎指正。
相关推荐:
30行代码让你理解angular依赖注入:angular 依赖注入原理
以上是深度解析AngularJS依賴注入原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

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

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

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

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

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

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

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

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