Angular的InjectionToken抛出“没有提供InjectionToken”的错误。
创始人
2024-10-24 06:01:14
0

在Angular中,当你使用InjectionToken时,如果没有提供相应的InjectionToken,就会抛出没有提供InjectionToken的错误。这通常发生在以下几种情况下:

  1. 没有在模块的providers数组中提供InjectionToken

    import { InjectionToken } from '@angular/core';
    
    // 创建一个InjectionToken
    export const MY_TOKEN = new InjectionToken('myToken');
    
    @NgModule({
      // 没有在providers中提供MY_TOKEN
      providers: [],
      ...
    })
    export class AppModule { }
    

    解决方法是在模块的providers数组中提供InjectionToken

    import { InjectionToken } from '@angular/core';
    
    export const MY_TOKEN = new InjectionToken('myToken');
    
    @NgModule({
      providers: [
        // 提供MY_TOKEN
        { provide: MY_TOKEN, useValue: 'myValue' },
      ],
      ...
    })
    export class AppModule { }
    
  2. 在组件或服务的构造函数中使用InjectionToken,但没有提供相应的InjectionToken

    import { Component, Inject } from '@angular/core';
    import { MY_TOKEN } from './app.module';
    
    @Component({
      selector: 'app-my-component',
      template: '...',
    })
    export class MyComponent {
      // 在构造函数中使用MY_TOKEN但没有提供
      constructor(@Inject(MY_TOKEN) private myValue: string) { }
    }
    

    解决方法是在提供InjectionToken的模块中提供相应的值:

    import { Component, Inject } from '@angular/core';
    import { MY_TOKEN } from './app.module';
    
    @Component({
      selector: 'app-my-component',
      template: '...',
    })
    export class MyComponent {
      constructor(@Inject(MY_TOKEN) private myValue: string) { }
    }
    
    @NgModule({
      providers: [
        { provide: MY_TOKEN, useValue: 'myValue' },
      ],
      ...
    })
    export class AppModule { }
    

请注意,InjectionToken可用于解决依赖注入中的循环依赖问题以及在编译时进行类型检查。确保在使用InjectionToken时遵循上述解决方法,以避免抛出没有提供InjectionToken的错误。

相关内容

热门资讯

信息共享!新超圣正版辅助,拼三... 信息共享!新超圣正版辅助,拼三张辅助器,力荐教程(确实有挂);新超圣正版辅助免费下载原版,在新超圣正...
一分钟揭秘!皇豪互众插件,微信... 一分钟揭秘!皇豪互众插件,微信新众游辅助,插件教程(讲解有挂);一分钟揭秘!皇豪互众插件,微信新众游...
玩家必备教程!青鸟辅助安卓,蛮... 玩家必备教程!青鸟辅助安卓,蛮王大厅辅助插件,扑克教程(有挂辅助);1、这是跨平台的蛮王大厅辅助插件...
玩家必看教程!潘茄辅助,新二号... 玩家必看教程!潘茄辅助,新二号辅助软件下载,软件教程(有挂头条);亲,有的,ai轻松简单,又可以获得...
让我来分享经验!新超凡软件辅助... 让我来分享经验!新超凡软件辅助,新八戒辅助,必备教程(有挂技巧);最新版2026是一款经典耐玩的益智...
一分钟了解!新518互游脚本,... 一分钟了解!新518互游脚本,超级三加一正版,科技教程(确实有挂)是一款可以让一直输的玩家,快速成为...
一分钟了解!新西楚辅助器,超级... 您好:超级三加一辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特...
普及知识!钱塘十水三攻略,新青... 普及知识!钱塘十水三攻略,新青鸟辅助,专业教程(有挂规律);钱塘十水三攻略AI智能教程细节普及钱塘十...
玩家必看!新蛮王辅助器,西兵互... 玩家必看!新蛮王辅助器,西兵互娱辅助插件app,必胜教程(真的有挂);1、让任何用户在无需AI插件第...
一分钟快速了解!新天道挂机辅助... 一分钟快速了解!新天道挂机辅助,新西楚辅助,必赢教程(确实有挂);1、玩家可以在新天道挂机辅助软件透...