0

我已经写了angular2的远​​程记录器,它工作正常。我现在想将它作为自己的npm库发布,并努力使其可用。我将自己定位于ngx-translate模块的设置。建立和发布angular2模块

我内部使用记录仪的一般设置类似于Ben Nadel's Custom Error Handler Post描述的:

import { 
    LOG4NG_SERVICE_HANDLER_PROVIDERS, 
    LOG4NG_SERVICE_CONFIG, 
    LOG4NG_ERROR_HANDLER_PROVIDERS, 
    LOG4NG_ERROR_HANDLER_CONFIG } from './log4ng.service'; 
import * as message from './log4ng.service/message'; 

@NgModule({ 
    declarations: [ 
    AppComponent 
    ], 
    imports: [ 
    BrowserModule, 
    FormsModule, 
    HttpModule 
    ], 
    providers: [ 
    LOG4NG_SERVICE_HANDLER_PROVIDERS, 
    { 
     provide: LOG4NG_SERVICE_CONFIG, 
     useValue: { 
     recipients: [ 
      { 
      classname: 'ConsoleWriter', 
      params: { 
       name: 'Angular2 Test App::Console Logger' 
      } 
      } 
     ], 
     filters: [ /** filter definition **/ ] 
     } 
    }, 

    LOG4NG_ERROR_HANDLER_PROVIDERS, 
    { 
     provide: LOG4NG_ERROR_HANDLER_CONFIG, 
     useValue: { 
     rethrowError: false, 
     unwrapError: false 
     } 
    } 
    ], 
    bootstrap: [AppComponent] 
}) 
export class AppModule { } 

我试过这种方法适应它自己的模块,像这样:

import { NgModule, ModuleWithProviders } from '@angular/core'; 
import { CommonModule } from '@angular/common'; 
import { 
    Log4ngService, 
    ILog4ngServiceConfig, 
    LOG4NG_SERVICE_CONFIG, 
    LOG4NG_SERVICE_HANDLER_PROVIDERS, 
    ErrorHandlerLoggingService, 
    LOG4NG_ERROR_HANDLER_CONFIG, 
    LOG4NG_ERROR_HANDLER_PROVIDERS 
} from './src'; 

export * from './src'; 

@NgModule({ 
    imports: [ 
    CommonModule 
    ], 
    providers: [ 
    Log4ngService, 
    ErrorHandlerLoggingService 
    ] 
}) 
export class Log4ngModule { 
    static forRoot(config: ILog4ngServiceConfig = LOG4NG_SERVICE_CONFIG): ModuleWithProviders { 
     return { 
      ngModule: Log4ngModule, 
      providers: LOG4NG_SERVICE_HANDLER_PROVIDERS 
     }; 
    } 

    static forChild(config: ILog4ngServiceConfig = LOG4NG_SERVICE_CONFIG): ModuleWithProviders { 
     return { 
      ngModule: Log4ngModule, 
      providers: LOG4NG_SERVICE_HANDLER_PROVIDERS 
     }; 
    } 
} 

我开始创建一个demo-app来使用这个模块,并使用npm link在本地使用库文件。虽然它完全建立,试图演示程序使用它的时候,我得到的运行时错误:

Error: Can't resolve all parameters for Log4ngService: (?) 

我不明白,既然我的理解,所有必要的DI令牌设置是否正确。

你可以在这个混帐的仓库的开发分支找到代码:https://github.com/LarsKumbier/log4ng/tree/dev

任何帮助和提示赞赏 - 在此先感谢!

+0

一厂什么,我没有,因为你不使用它们的参数'config'为什么要使用forRoot和forChild明白了吗? –

+0

是的,那些是ngx-translate的残余,有些尝试解决这个问题。应该删除那些。 – Lars

回答

0

,因为这个问题是在Log4ngService你可以使用这样

/** Log4ngService factory */ 
    export function Log4ngServiceFactory(config: ILog4ngServiceConfig) { 
     return new Log4ngService (config); 
    } 

    @NgModule({ 
     imports: [ 
     CommonModule 
     ], 
     providers: [ 
     ErrorHandlerLoggingService 
     ] 
    }) 
    export class Log4ngModule { 
     static forRoot(config: ILog4ngServiceConfig = LOG4NG_SERVICE_CONFIG): ModuleWithProviders { 
       return { 
        ngModule: Log4ngModule, 
        providers: [ 
        { 
         provide: Log4ngService, 
         useFactory: Log4ngServiceFactory, 
         deps : [config] 
        } 
        ] 
       }; 
      } 
    }