linkFactoryProvider
npm Package | @angular/core |
---|---|
Module | import { FactoryProvider } from '@angular/core'; |
Source | core/src/di/provider.ts |
Configures the Injector
to return a value by invoking a useFactory
function.
linkInterface Overview
interface FactoryProvider {
provide: any
useFactory: Function
deps?: any[]
multi?: boolean
}
linkHow To Use
function serviceFactory() { ... }
const provider: FactoryProvider = {provide: 'someToken', useFactory: serviceFactory, deps: []};
linkDescription
For more details, see the "Dependency Injection Guide".
linkExample
const Location = new InjectionToken('location');
const Hash = new InjectionToken('hash');
const injector = Injector.create([
{provide: Location, useValue: 'http://angular.io/#someLocation'}, {
provide: Hash,
useFactory: (location: string) => location.split('#')[1],
deps: [Location]
}
]);
expect(injector.get(Hash)).toEqual('someLocation');
Dependencies can also be marked as optional:
const Location = new InjectionToken('location');
const Hash = new InjectionToken('hash');
const injector = Injector.create([{
provide: Hash,
useFactory: (location: string) => `Hash for: ${location}`,
// use a nested array to define metadata for dependencies.
deps: [[new Optional(), Location]]
}]);
expect(injector.get(Hash)).toEqual('Hash for: null');
linkMembers
useFactory: Function
A function to invoke to create a value for this token
. The function is invoked with
resolved values of token
s in the deps
field.
deps?: any[]
A list of token
s which need to be resolved by the injector. The list of values is then
used as arguments to the useFactory
function.
multi?: boolean
If true, then injector returns an array of instances. This is useful to allow multiple providers spread across many files to provide configuration information to a common token.
linkExample
const locale = new InjectionToken<string[]>('locale');
const injector = Injector.create([
{provide: locale, multi: true, useValue: 'en'},
{provide: locale, multi: true, useValue: 'sk'},
]);
const locales: string[] = injector.get(locale);
expect(locales).toEqual(['en', 'sk']);