获得'ngbCollapse',因为它不是'div'的已知属性.将组件移动到子模块后出错

Leo*_*ban 8 javascript angular-module angular-components angular

错误

compiler.js:215未捕获错误:模板解析错误:无法绑定到'ngbCollapse',因为它不是'div'的已知属性.( "] [ngbCollapse] =" 是否隐藏">

我有一个NavbarComponent和一个FooterComponent,我想进入SharedModule,以保持根app.module更清洁.

app.module

import { AdminComponent } from './admin/admin.component';
// import { NavbarComponent } from './navbar/navbar.component';
// import { FooterComponent } from './footer/footer.component';

// Modules
import { DashboardModule } from './dashboard/dashboard.module';
import { HomeModule } from './home/home.module';

@NgModule({
  declarations: [
    AppComponent,
    LoginComponent,
    RegisterComponent,
    PasswordResetComponent,
    ResetPasswordComponent,
    AdminComponent,
    // NavbarComponent,
    // FooterComponent,
Run Code Online (Sandbox Code Playgroud)

share.module

但是,一旦我将这些组件移动到这里,并正确更新其路径./- > ../应用程序中断.

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';

import { NavbarComponent } from '../navbar/navbar.component';
import { FooterComponent } from '../footer/footer.component';
import { TermsComponent } from './terms.component';
import { PageNotFoundComponent } from './not-found.component';
import { PrivacyPolicyComponent } from './privacy-policy.component';

@NgModule({
  imports: [
    CommonModule
  ],
  declarations: [
    NavbarComponent,
    FooterComponent,
    TermsComponent,
    PageNotFoundComponent,
    PrivacyPolicyComponent
  ]
})
export class SharedModule { }
Run Code Online (Sandbox Code Playgroud)

navbar.component.ts

import { Component, OnInit } from '@angular/core';
import { AuthService } from '../auth.service';
import { environment } from '../../environments/environment';

@Component({
  selector: 'app-navbar',
  templateUrl: './navbar.component.html',
  styleUrls: ['./navbar.component.scss']
})
export class NavbarComponent implements OnInit {
  isHidden = true;
  oauthUrl = this.authService.generateOauthUrl();

  constructor(public authService: AuthService) { }

  ngOnInit() {
  }

  logout() {
    sessionStorage.clear();
  }
}
Run Code Online (Sandbox Code Playgroud)

随后几行与[ngbCollapse]navbar.component.html

<div *ngIf="!authService.isLoggedIn()" class="collapse navbar-collapse" id="navbarSupportedContent" [ngbCollapse]="isHidden">
Run Code Online (Sandbox Code Playgroud)

我认为这与相对路径,任何想法有关?

Con*_*Fan 12

ng-bootstrap在Angular模板中使用组件和指令,您需要导入NgbModule.在您的情况下,您应该导入它SharedModule.此外,为了在应用程序的其他部分中使用共享组件,您应该从中导出它们,SharedModuleSharedModule在使用组件时导入模块.

shared.module.ts

...
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';

@NgModule({
  imports: [
    CommonModule,
    NgbModule
  ],
  declarations: [
    NavbarComponent,
    FooterComponent,
    TermsComponent,
    PageNotFoundComponent,
    PrivacyPolicyComponent
  ],
  exports: [
    NavbarComponent,
    FooterComponent,
    TermsComponent,
    PageNotFoundComponent,
    PrivacyPolicyComponent
  ]
})
export class SharedModule { }
Run Code Online (Sandbox Code Playgroud)

app.module.ts

import { SharedModule } from './shared/shared.module';
...

@NgModule({
  imports: [
    SharedModule,
    ...
  ],
  ...
})
Run Code Online (Sandbox Code Playgroud)

注意:如果你想使用ng-bootstrap的部件和指令模板之外SharedModule,你应该添加NgbModuleexportsSharedModule.

  • AH gotcha :)关于导出数组 (2认同)
  • 是的,这个答案应该解决两个问题。:-) (2认同)