Не удалось разрешить подпись для вызова канала в vscode с помощью Angular Language Service - PullRequest
1 голос
/ 16 марта 2020

У меня есть pipesModule в Angular проект библиотеки , когда я импортирую модуль в другой проект, я получил сообщение об ошибке: Unable to resolve signature for pipe invocation в коде vs, он все еще работает, сборка без ошибок , но я понятия не имею, как это исправить, я получил так много красных линий ...

Теперь подсказка ошибки изменилась после обновления, например: Unable to resolve signature for call of pipeName, но я думаю, что это означает то же самое вещь

Каждая труба может получить эту ошибку, я не могу перенести красную линию ..., но она может быть решена с помощью веб-шторма.

Error Tip Screenshot

Это все, а что не так?

Angular Библиотечный проект

Angular Library Project
├─src
│  ├─pipes
│  │  ├─hide-tel.pipe.ts
│  │  ├─pipes.module.ts
│  │  └─index.ts
│  ├─public_api.ts
...
  • hide-tel.pipe.ts
import {Pipe, PipeTransform} from '@angular/core';

@Pipe({
  name: 'hideTel'
})
export class HideTelPipe implements PipeTransform {
  transform(value: string): string {
    return value.slice(0, 3) + '****' + value.slice(-4);
  }
}

  • pipe.module.ts
import { NgModule } from '@angular/core';
import { HideTelPipe } from './hide-txt.pipe';

const PIPES = [
  HideTelPipe,
];

@NgModule({
  declarations: [ ...PIPES ],
  exports: [ ...PIPES ],
})
export class PipesModule {}

  • index.ts
export * from './hide-tel.pipe';
export * from './pipes.module';
  • public_api.ts
export * from './pipes/index';

Вопрос проекта

Question Project
├─src
│  ├─my-common
│  │  └─my-common.module.ts
│  ├─app
│  │  └─some
│  │     ├─some.component.html
│  │     ├─some.component.scss
│  │     └─some.component.ts
│  ├─app.module.ts
...
  • my-common.module.ts
import {ModuleWithProviders, NgModule} from '@angular/core';
import {FormsModule} from '@angular/forms';
import {CommonModule} from '@angular/common';

const MODULES = [
  CommonModule,
  FormsModule,
  PipesModule,
];

@NgModule({
  imports: [
    ...MODULES,
  ],
  declarations: [],
  exports: [
    ...MODULES,
  ],
  providers: [],
})
export class MyCommonModule {
  static forRoot(): ModuleWithProviders {
    return {
      ngModule: MyCommonModule,
      providers: [],
    };
  }
}
  • app.module.ts
import {BrowserModule} from '@angular/platform-browser';
import {ErrorHandler, NgModule} from '@angular/core';
import {RouterModule} from '@angular/router';
import {AppComponent} from './app.component';
import {TransferHttpCacheModule} from '@nguniversal/common';
import {HttpClientModule} from '@angular/common/http';
import {CommonModule} from '@angular/common';
import {FormsModule} from '@angular/forms';
import {BrowserAnimationsModule} from '@angular/platform-browser/animations';
import {environment} from '../environments/environment';
import {APP_ROUTES} from './app.routing';
import {MyCommonModule} from './my-common/my-common.module';

import {SomeComponent} from './app/some/some.component.ts';

@NgModule({
  declarations: [
    AppComponent,
    SomeComponent,
  ],
  imports: [
    CommonModule,
    FormsModule,
    BrowserAnimationsModule,
    MyCommonModule.forRoot(),
    BrowserModule.withServerTransition({appId: 'my-app'}),
    RouterModule.forRoot(APP_ROUTES, {
      useHash: false
    }),
    TransferHttpCacheModule,
    HttpClientModule,
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule {
}
  • some.component. html
<div>{{ telNumber | hideTel }}</div>
       〰️〰️〰️〰️〰️〰️〰️〰️〰️
=======^================================================
  x some.component.html 1 of 1 problems
--------------------------------------------------------
  Unable to resolve signature for call of hideTelng
========================================================

1 Ответ

0 голосов
/ 23 апреля 2020

Может быть разрешено с помощью опции "preserveSymlinks": true в tsconfig. json

  • tsconfig. json
{
    ...
    "compilerOptions": {
        ...
        "preserveSymlinks": true,
    },
}
...