Aller au contenu principal
Version: 3.0.0

Self-executing code

In the initialization process, when our code has nothing to do with the main process but wants to execute it, it will usually be executed in the startup onReady phase. As the amount of code increases, the onReady will become bloated.

For example, we have some logic that needs to be executed in advance, one for listening for Redis errors and the other for initializing data synchronization:

@Provide()
@Scope(ScopeEnum.Singleton)
export class RedisErrorListener {
// ...
}

@Provide()
@Scope(ScopeEnum.Singleton)
export class DataSyncListener {
// ...
}

In general, we will create an instance at startup by getAsync methods to make it execute.



// configuration.ts
//...

@Configuration({
// ...
})
export class MainConfiguration {
async onReady(container) {
await container.getAsync(RedisErrorListerner);
await container.getAsync(DataSyncListerner);
}
}

In this way, once there is more code, there will be many unnecessary process codes in onReady.

Self-initialization

If the code is not coupled to the main process and belongs to independent logic, such as listening to some events and initializing data synchronization, you can use the @Autoload decorator to enable a class to initialize itself.

For example:

import { Autoload, Scope, ScopeEnum } from '@midwayjs/core';

@Autoload()
@Scope(ScopeEnum.Singleton)
export class RedisErrorListener {
@Init()
async init() {
const redis = new Redis();
redis.on('xxx', () => {
// ...
});
}
}

This automatically initializes without using the getAsync method in onReady and executes the init method.