无法找到自定义管道

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了无法找到自定义管道相关的知识,希望对你有一定的参考价值。

我已经建了一个管子,但我不知道为什么棱角分明找不到它。

我的顶级模块是我的shared.module

该模块又由browser.module或server.module集成。

此外,我有一个user.module作为最低级别,所有用户的组件都进入。

如果我在user.module中定义我的管道,将找到管道。

import { ExponentialStrengthPipe } from '../../exponential-strength.pipe';
[...]

@NgModule({
    declarations: [ [...]

        ExponentialStrengthPipe
    ],
    imports: [
        CommonModule,
        HttpModule,
        FormsModule,
        ReactiveFormsModule,
        RouterModule.forChild([...])
    ],

})
export class UserModule {
    constructor(
    ) {
    }

}

如果我在我的共享中安装它。模块,没有了。

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { ExponentialStrengthPipe } from './exponential-strength.pipe';
[...]
@NgModule({
    declarations: [
        AppComponent,
[...]
        ExponentialStrengthPipe
    ],

    providers: [
        UserService

    ],
    imports: [
        CommonModule,
        RouterModule.forRoot([
            { path: 'home', component: HomeComponent },
            { path: '', redirectTo: 'home', pathMatch: 'full' },
            { path: '**', component: PageNotFoundComponent },
        ]),
    ],
    exports: [
        ExponentialStrengthPipe
        ]

})
export class AppModuleShared {
    constructor(
    ) {
    }

}
答案

如果要在其他模块中使用管道,则将声明管道的模块添加到要重新使用管道的模块的imports: [...],而不是将其添加到模块的declarations: []。如果你在多个declarations:[]中添加管道,你会收到一个错误,抱怨你已经在多个模块中声明了管道。因此,在这种情况下,您必须在共享模块的declarations: []中添加管道,并将共享模块添加到要使用管道的模块中的imports: [...]。 (例如:用户模块)

以上是关于无法找到自定义管道的主要内容,如果未能解决你的问题,请参考以下文章

片段中的自定义列表视图。未找到布局

片段中ListView的android自定义适配器

在片段中创建自定义列表视图时出错。必需的活动,找到的片段

在片段中创建自定义列表视图时出错所需活动,找到片段

找不到管道:Angular 5 自定义管道

用于自定义操作的 sklearn 管道