super easy and super small dependency injection - all that you need
- no need to register
- can override
- can use inject
- can use decorators
- you have a tree of objects
- one day you decide to have a similarly constructed component
- but the problem is at some branch/leaf you want a different class
- the rest is the same
- in the branch/leaf use
DIContainer.getClass(Slot)
to get class ofSlot
- in the cloned component use
DIContainer.setClass(Slot, NewComponent)
- in original component that resolves to
Slot
- in cloned component that resolves to
NewComponent
import { DIContainer } from 'inject.min';
class Original {
name = 'original';
}
class Override extends Original {
name = 'override';
}
class TestGet {
constructor() {
const Class = DIContainer.getClass(Original);
const instance = new Class();
console.log(Class.name, instance.name);
}
}
class TestOverride extends TestGet {
constructor() {
DIContainer.setClass(Original, Override);
super();
}
}
// 'Original', 'original'
new TestGet();
// 'Override', 'override'
new TestOverride();
modify your tsconfig.json
{
"compilerOptions": {
"experimentalDecorators": true
}
}
import { Inject } from 'inject.min';
class Example {
value: string;
constructor(props?: { param: string }) {
this.value = props?.param || 'example';
}
}
class Example2 extends Example {
constructor(param: string) {
super({ param });
}
}
class Test {
@Inject(Example) example: Example;
@Inject(Example2, 'example2') example2: Example2;
@Inject(Example, { param: 'example3' }) example3: Example;
constructor() {
console.log(this.example.value); // example
console.log(this.example2.value); // example2
console.log(this.example3.value); // example3
}
}
class Test2 {
@Inject(Example) example: Example;
@Inject(Example2, 'different') example2: Example2;
@Inject(Example, { param: 'example3' }) example3: Example;
constructor() {
console.log(this.example.value); // example
console.log(this.example2.value); // different
console.log(this.example3.value); // example3
}
}
class Test3 extends Test {}
const test = new Test(); // example, example2, example3
const test2 = new Test2(); // example, different, example3
const test3 = new Test3(); // example, example2, example3
console.log(test.example === test2.example); // true
console.log(test.example2 === test2.example2); // false
console.log(test.example2 === test3.example2); // true
npm i inject.min --save
MIT