AngularWebWorker如何访问共享函数?
创始人
2024-10-29 22:30:26
0
  1. 将共享函数封装在一个模块中,通过 Angular 的 Provider 注册到主应用程序和 Web Worker 中。
// shared.module.ts
import { NgModule } from '@angular/core';
import { SharedService } from './shared.service';

@NgModule({
  providers: [SharedService]
})
export class SharedModule {}

// shared.service.ts
import { Injectable } from '@angular/core';

@Injectable()
export class SharedService {
  public sharedFunction(): void {
    console.log('Shared function called');
  }
}
  1. 在主应用程序中,将共享模块导入 AppModule 并设置为全局可用。
// app.module.ts
import { NgModule } from '@angular/core';
import { SharedModule } from './shared/shared.module';

@NgModule({
  imports: [SharedModule]
})
export class AppModule {}
  1. 在 Web Worker 中创建一个新的 AppModule 并导入 SharedModule。
// worker-app.module.ts
import { NgModule } from '@angular/core';
import { SharedModule } from '../shared/shared.module';

@NgModule({
  imports: [SharedModule]
})
export class WorkerAppModule {}
  1. 在 Web Worker 中,手动启动应用程序并将 WorkerAppModule 作为根模块。
// worker.ts
import { platformWorkerAppDynamic } from '@angular/platform-webworker-dynamic';
import { WorkerAppModule } from './worker-app/worker-app.module';

platformWorkerAppDynamic().bootstrapModule(WorkerAppModule);
  1. 在 Web Worker 中,注入 SharedService 并调用共享函数。
// worker.component.ts
import { Component } from '@angular/core';
import { SharedService } from '../../shared/shared.service';

@Component({
  selector: 'app-worker',
  template: 'Worker component'
})
export class WorkerComponent {
  constructor(private sharedService: SharedService) {
    this.sharedService.sharedFunction();
  }
}
  1. 在主应用程序中,通过 MessageEvent 向 Web Worker 发送消息,并在 Web Worker 中接收并处理该消息。
// app.component.ts
import { Component, OnInit } from '@angular/core';

@Component({
  selector: 'app-root',

相关内容

热门资讯

德州之星有外 挂!德州之星ap... 德州之星有外 挂!德州之星app辅助,云扑克德州其实存在有挂(详细数据软件教程)是一款可以让一直输的...
第三方教程!wepooke a... 第三方教程!wepooke app系统规律(we辅助poker德之星)WepokE(都是真的有挂);...
微扑克ai辅助!Wpk的确真的... 微扑克ai辅助!Wpk的确真的有挂,wpK其实真的有挂,必备教程(有挂攻略);1、打开软件启动之后找...
微扑克ai辅助器苹果版!aa扑... 微扑克ai辅助器苹果版!aa扑克软件,aapoker德州线上扑克(详细辅助挂教程);支持2-10人实...
德州之星有外 挂!德扑ai智能... 德州之星有外 挂!德扑ai智能机器人平台安装,德扑平台其实是真的有挂(详细外 挂教程);是一款可以让...
wpk发牌逻辑!wpk德州职业... wpk发牌逻辑!wpk德州职业代打(Wpk)就是真的有挂-详细透明挂教程1、构建自己的wpk辅助插件...
wepoke有辅助挂!wopo... wepoke有辅助挂!wopoker分析器,wepoke是有软件,AI教程(有挂方法);玩家必备必赢...
德扑ai智能!wepower德... 您好,德扑ai智能这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款...
wepokeai代打的胜率!w... wepokeai代打的胜率!wepoke是是有挂,wePOke都是真的有挂,2025新版总结(有挂黑...
wpk真的有外 挂!wpK原来... wpk真的有外 挂!wpK原来真的有挂,Wpk本来真的有挂,专业教程(有挂细节);wpk真的有外 挂...