For strongly typed static languages like Java, IoC / DI frameworks / toolkits are invaluable to decouple the complex systems thus make the sub-components unit testable and their composition fluently.
Most of us cite that Javascript as loosely typed dynamic language already offers the major benefits of IoC / DI in spirit, while some insist that higher level abstraction / implementation should be in place.
For the latter, what are those common IoC / DI implementations in Javascript realm?
Inversion of Control(IoC) is also known as Dependency injection (DI). The Spring container uses Dependency Injection (DI) to manage the components that build up an application and these objects are called Spring Beans. Spring implements DI by either an XML configuration file or annotations.
IoC frameworks implement common, low-level and problem-prone activities. This allows the developer to focus on custom business logic, instead of struggling with tedious infrastructure or configuration tasks.
IOC is technique where you let someone else to create the object for you. And the someone else in case of spring is IOC container. Dependency Injection is a technique where one object supplies the dependency of another object.
Dependency Injection is a programming technique where dependencies are not created by function or classes themselves but are provided via injections. It's one of the implementations of the Inversion of Control principle where the framework controls the app's flow and up to the developer is to provide the custom logic.
Please have a look into wire.js. This is my choice and it works great.
The main features are:
- Simple, declarative dependency injection
- A flexible, non-invasive connection infrastructure
- Application lifecycle management
- Powerful core tools and plugin architecture for integrating popular frameworks and existing code.
- Support for both browser and server environments
Also please check some alternatives npm modules for DI
Javascript's Duck-Typing allows us to easily mock dependencies.
Here is a quick example of how you could do this:
We have a simple function which represents an item being added to the database. DB is a dependency which we will want to mock.
function SaveItem(item){
var db = new DB();
db.insert(item);
};
If we change the DB dependency to be a parameter, then we can inject whatever we want. When the function is called it checks to see if the dataStore parameter exists. When the item exists the value is assigned to db. When dataStore is null or undefined, then a new DB object is created instead. This allows you to inject in your dependency with the confidence that db will always have a value.
function SaveItem(item, dataStore){
var db = dataStore || new DB();
db.insert(item);
};
Now we can mock our dependency like so:
function mockDb(){
return{
insert: function(){
assert(true);
}
}
};
And to bring it all together in a test:
function SaveItemShouldCallInsertOnDb = function(){
var testDb = new mockDb();
var someTestItem = { name: "test item" };
SaveItem(someTestItem, testDb);
};
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With